当前位置: 首页 > wzjs >正文

天津市建设网站阿里巴巴外贸圈app

天津市建设网站,阿里巴巴外贸圈app,自己怎么设计网页,浙江最近爆发的传染病文章目录 样式穿透:deep()scoped的原理 插槽选择器:slotted()全局选择器:global()动态绑定CSScss module 样式穿透:deep() 主要是用于修改很多vue常用的组件库(element, vant, AntDesigin),虽然配好了样式但是还是需要更改其他的样式就需要用…

文章目录

  • 样式穿透:deep()
    • scoped的原理
  • 插槽选择器:slotted()
  • 全局选择器:global()
  • 动态绑定CSS
  • css module

样式穿透:deep()

主要是用于修改很多vue常用的组件库(element, vant, AntDesigin),虽然配好了样式但是还是需要更改其他的样式就需要用到样式穿透。

scoped的原理

vue中的scoped 通过在DOM结构以及css样式上加唯一不重复的标记:data-v-hash的方式,以保证唯一(而这个工作是由过PostCSS转译实现的),达到样式私有化模块化的目的。

scoped三条渲染规则:

  1. 给HTML的DOM节点加一个不重复data属性(形如:data-v-123)来表示他的唯一性
  2. 在每句css选择器的末尾(编译后的生成的css语句)加一个当前组件的data属性选择器(如[data-v-123])来私有化样式
  3. 如果组件内部包含有其他组件,只会给其他组件的最外层标签加上当前组件的data属性

在这里插入图片描述
这是组件内部包含有其他组件的情况(当前.vue文件也是一个组件),只会给其他组件的最外层标签加上当前组件的data属性

如果不写Scoped 就没问题

原因就是Scoped 搞的鬼 他在进行PostCss转化的时候把元素选择器默认放在了最后。

上面提到第三条的规则 因为当前组件标签是没有这个属性标签的,所以无法修改样式。

在这里插入图片描述

Vue 提供了样式穿透 /deep/(vue2写法) :deep()(vue3写法) 他的作用就是用来改变 属性选择器的位置
在这里插入图片描述
在这里插入图片描述

:deep()原理很简单,就是将属性标签提到外层。


插槽选择器:slotted()

使用场景:在使用插槽组件的时候写样式,默认不会影响 <slot/> 渲染出来的内容,因为它们被认为是父组件所持有并传递进来的。

<template><div><A><div class="a">私人定制div</div></A></div>
</template><script setup>
import A from "@/components/A.vue"
</script><style lang="less" scoped>
</style>
<template><div>我是插槽<slot></slot></div>
</template><script>
export default {}
</script><style scoped>.a{不会生效的color:red
}这样就可以修改父组件中定义的.a的样式:slotted(.a) {color:red
}
</style>

全局选择器:global()

在之前我们想加入全局 样式 通常都是新建一个style 标签 不加scoped 现在有更优雅的解决方案

<style>div{color:red}
</style><style lang="less" scoped></style>

使用全局选择器

<style lang="less" scoped>
:global(div){color:red
}
</style>

动态绑定CSS

单文件组件的 <style> 标签可以通过 v-bind 这一 CSS 函数将 CSS 的值关联到动态的组件状态上:

<template><div class="div">红色</div><div class="pink">粉色</div>
</template><script lang="ts" setup>
import { ref } from 'vue'
const red = ref<string>('red')
setTimeout(()=>{red.value = 'blue'
},2000)const pink= ref({color:'pink'
})</script><style lang="less" scoped>
.div{color:v-bind(red)
}
.pink{对象形式需要使用单引号color:v-bind('pink.color')
}</style>

css module

<style module> 标签会被编译为 CSS Modules 并且将生成的 CSS 类作为 $style 对象的键暴露给组件

<template><div :class="$style.red">11111</div>
</template><style module>
.red {color: red;font-size: 20px;
}
</style>

自定义注入名称(多个可以用数组)

<template>这里可以使用数组的形式添加多个<div :class="[zs.red,zs.border]">111</div>
</template>这里自定义了名称为zs
<style module="zs">
.red {color: red;font-size: 20px;
}
.border{border: 1px solid #ccc;
}
</style>

与组合式 API 一同使用

注入的类可以通过 useCssModule APIsetup() <script setup> 中使用。对于使用了自定义注入名称的 <style module> 模块,useCssModule 接收一个对应的 module attribute 值作为第一个参数(了解即可 不常用 一般用于jsx、render 函数中)

<template><div :class="[zs.red,zs.border]">111</div>
</template><script setup lang="ts">
import { useCssModule } from 'vue'
const css = useCssModule('zs')
console.log(css)
</script><style module="zs">
.red {color: red;font-size: 20px;
}
.border{border: 1px solid #ccc;
}
</style>


文章转载自:

http://vAmeoVSV.jtfsd.cn
http://VCqwprAD.jtfsd.cn
http://nmZKRmo8.jtfsd.cn
http://Fyyvy56E.jtfsd.cn
http://KvRQolXs.jtfsd.cn
http://63rwfNAr.jtfsd.cn
http://vjCIDgnd.jtfsd.cn
http://Zz8Pz8A7.jtfsd.cn
http://26XBuAGZ.jtfsd.cn
http://39TxwiTw.jtfsd.cn
http://AtN2aaaZ.jtfsd.cn
http://rsZbVR1U.jtfsd.cn
http://LjYGr9bc.jtfsd.cn
http://8iwN5lZt.jtfsd.cn
http://EEaENAJr.jtfsd.cn
http://bfrD0Q9j.jtfsd.cn
http://G7IeSEt7.jtfsd.cn
http://IVYbEtPy.jtfsd.cn
http://cFVPfPmW.jtfsd.cn
http://JApYMDsX.jtfsd.cn
http://HPhnmPs2.jtfsd.cn
http://9tYvqidZ.jtfsd.cn
http://iloFdMj3.jtfsd.cn
http://0VbavZXj.jtfsd.cn
http://yDwdzYlx.jtfsd.cn
http://pTUetwzI.jtfsd.cn
http://sHVUlzZc.jtfsd.cn
http://GS8ZNizC.jtfsd.cn
http://TuLu7qXz.jtfsd.cn
http://XzOm6wfK.jtfsd.cn
http://www.dtcms.com/wzjs/648033.html

相关文章:

  • 长沙河西做网站用python做网站优点
  • 下载站cmsWordPress多功能新闻积分商城主题
  • 移动端网站如何做导出功能梧州房源信息网
  • 网站建设服务器是什么软件应用
  • 创建个人主页网站设计模式
  • 免费淘宝客网站模板下载设计外贸网站
  • 百度云虚拟主机如何建设网站安福网站制作
  • 建立网站需要哪几个怎么搭建自己的网站卖货
  • 黑龙江省建设教育信息网站广州网站建设好公司
  • 网站开发语言 排行榜瑞安网站建设电话
  • 怀来县建设局网站室内设计师收入高吗
  • 单页导航网站模板wordpress自动标签插件
  • 哪个网站有代做课设的网站怎么找回密码
  • 网站建设网站搭建公众号同步到dede网站
  • 阿里云建站和华为云建站兰州app定制开发
  • 网站设计步骤图佛山定制网站建设
  • 松江新城建设集团有限公司网站河南建设监理协会官方网站
  • 家具网站设计网站wordpress 教育
  • 建设银行广西分行招聘网站个人电子商务网站建设方案
  • 我的世界建筑网站深圳营销型网站公司
  • 网站建设案例图片村网通为每个农村建设了网站
  • 工作准备区域的组成包括企业网站seo怎么做
  • 玉溪定制网站建设网页设计这个行业怎么样
  • 500亿网站建设免费软件库下载
  • 广西城乡建设名网站门窗 东莞网站建设
  • 主流网站开发技术框架美文网站源码
  • 阿尔山网站建设文化建设素材
  • 可以免费做3dLOGO的网站网络小说写作网站
  • 广州网站建设乐云seo模板中心江苏网站建设要多少钱
  • 无法进行网站备案百度站长平台链接提交