ant design vue 图片预览组件自定义样式

 更新时间:2023年05月16日 10:41:21   作者:youcans_  
这篇文章主要为大家介绍了ant design vue 图片预览组件自定义样式方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

版本:

ant design vue 3.2.4

场景:

使用Image图片组件预览功能

需求:

自定义预览遮罩层及预览图片的样式;

不得影响到其他页面or组件的样式;

for example,下图是预览组件默认样式:

我希望改个背景颜色,类似这样:

难点: 不同于modal,tooltip这种,Image组件没有给预览功能的wrapper直接赋值类名的属性(起码文档上没有提到);

那就意味着只能到把预览组件的样式改到全局作用域里,那势必会影响到别的页面的样式;

解决方式:

思路就是两个方面:

  • 把预览的整个组件放到一个自定义类名的dom元素里(默认是放在最外层body下的);

官方提供的相关的配置previewType:

{
    visible?: boolean; 
    onVisibleChange?: (visible, prevVisible) => void; 
    getContainer: string | HTMLElement | (() => HTMLElement);
}

        乍一看可以用getContainer来解决,whatever,太麻烦~

  • 回归本心,想办法给预览组件附上自定义类名;

        上antd源码,看看我发现了什么:

        prefixCls,针对这个文档中没提到的属性深入下去,先看setup的render

        关键在这儿:

    { "class": "".concat(prefixCls.value, "-mask-info") }

        不出所料哈,prefixCls这个props果然是提供给预览的遮罩层做类名的;

        那剩下事情就很简单了,只要给Image组件提供prefixCls的属性,把自定义的类名赋值上去就行了;类似这样~

        最后一个point:prefixCls是有默认值的,值为ant-image,如果直接给prefixCls赋值一个字符串,其实是把它的默认样式给覆盖掉了,;就需要从头写一套预览功能的样式,很麻烦;所以我们给prefixCls赋值时,完全可以像上图那样,采用 “自定义类名 ant-image” 的格式;然后就可以在保留原样式的基础上,快乐利用自定义类名去覆盖部分样式了;

end

以上就是ant design vue 图片预览组件自定义样式的详细内容,更多关于ant design vue 组件自定义的资料请关注脚本之家其它相关文章!

相关文章

  • 详解git commit --amend 用法

    详解git commit --amend 用法

    这篇文章主要介绍了详解git commit --amend 用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • git checkout 命令使用详解

    git checkout 命令使用详解

    这篇文章主要介绍了git checkout 命令使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • 使用MobaXterm连接到远程服务器的图文教程

    使用MobaXterm连接到远程服务器的图文教程

    这篇文章主要为大家详细为大家介绍了如何使用MobaXterm连接到远程服务器,文中通过图文进行了详细的讲解,有需要的小伙伴可以参考一下
    2023-09-09
  • 关于Interlij 无法使用中文输入法的解决方法(适用于Interlij全家桶 Linux环境)

    关于Interlij 无法使用中文输入法的解决方法(适用于Interlij全家桶 Linux环境)

    这篇文章主要介绍了关于Interlij 无法使用中文输入法的解决方法(适用于Interlij全家桶 Linux环境),本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • chatgpt-api使用指南详解教程【官方泄露版】

    chatgpt-api使用指南详解教程【官方泄露版】

    chatgpt-api是 OpenAI ChatGPT 的非官方的 Node.js 包装器, chatgpt-api不再需要任何浏览器破解它使用泄露出来的OpenAI官方ChatGPT 在后台使用的模型,这篇文章主要介绍了chatgpt-api使用指南【官方泄露版】,需要的朋友可以参考下
    2023-02-02
  • idea激活码最新获取方法(idea2020激活码汇总)

    idea激活码最新获取方法(idea2020激活码汇总)

    针对idea激活码失效的情况,我们给大家带来最新的idea激活码以及相关激活教程,分享最新idea激活参数等信息。
    2020-02-02
  • HTTP状态代码集合 方便查询

    HTTP状态代码集合 方便查询

    HTTP协议是基于请求/响应范式的。一个客户机与服务器建立连接后,发送一个请求给服务器,请求方式的格式为,统一资源标识符、协议版本号,后边是MIME信息包括请求修饰符、客户机信息和可能的内容。
    2011-02-02
  • 使用Visual Studio进行文件差异比较的问题小结

    使用Visual Studio进行文件差异比较的问题小结

    这篇文章主要介绍了使用Visual Studio进行文件差异比较,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-07-07
  • 分享18个最佳代码编辑器/IDE开发工具

    分享18个最佳代码编辑器/IDE开发工具

    这篇文章主要为开发人员收录了18个最好的代码编辑器/IDE工具,希望你会喜欢
    2014-05-05
  • Runnable.com 在线测试代码片分享网站

    Runnable.com 在线测试代码片分享网站

    Runnable是一个一站式的代码片段集合网站,你不仅可以搜索代码,还可以编辑、运行这些代码片段,以确保它们的正确性与可用性
    2013-12-12

最新评论