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

哪些公司可以做网站/百度关键词排名怎么靠前

哪些公司可以做网站,百度关键词排名怎么靠前,临淄房产信息网,空间网站建设前面的话 css modules是一种流行的模块化和组合CSS的系统。 vue-loader提供了与css modules的集成&#xff0c;作为scope CSS的替代方案。本文将详细介绍css modules 引入 最开始使用Vue的时候&#xff0c;提倡并大量使用的是scoped这种技术 <style scoped>media (min-wi…

前面的话

  css modules是一种流行的模块化和组合CSS的系统。 vue-loader提供了与css modules的集成,作为scope CSS的替代方案。本文将详细介绍css modules

 

引入

  最开始使用Vue的时候,提倡并大量使用的是scoped这种技术

<style scoped>@media (min-width: 250px) {.list-container:hover {background: orange;}}
</style>

  这个可选 scoped 属性会自动添加一个唯一的属性 (比如 data-v-21e5b78) 为组件内 CSS 指定作用域,编译的时候 .list-container:hover 会被编译成类似 .list-container[data-v-21e5b78]:hover

  但是,它并不能完全避免冲突

<span data-v-0467f817 class="errShow">用户名不得为空</span>

  以上面的代码为例,使用scoped之后,它在元素上添加了一个唯一的属性'data-v-0467f817',CSS样式被编译如下

.errShow[data-v-0467f817] {font-size: 12px;color: red;
}

  但是,如果用户也定义了一个errShow类名,会影响到所有定义为errShow类名的组件的显示

  而CSS modules则做的更彻底,它不是添加属性,而是直接改变类名

<span class="_3ylglHI_7ASkYw5BlOlYIv_0">用户名不得为空</span>

  这样,大大降低了冲突的可能性,只要不是用户直接给span标签设置样式,基本上不会影响组件的显示

 

模块化

  CSS Modules既不是官方标准,也不是浏览器的特性,而是在构建步骤中对CSS类名选择器限定作用域的一种方式(通过hash实现类似于命名空间的方法)。类名是动态生成的,唯一的,并准确对应到源文件中的各个类的样式

  实际上,CSS Modules只是CSS模块化的一种方式。为什么我们需要CSS模块化呢?

  CSS的规则都是全局的,任何一个组件的样式规则,都对整个页面有效。于是,亟待解决的就是样式冲突(污染)的问题。一般地,为了解决冲突,会把class命名写长一点,降低冲突几率;加上父元素的选择器,来限制范围等

  CSS模块化就是来解决这个问题的,一般地,分为三类

  1、命名约定类

  该类CSS模块化方案主要用来规范CSS命名,最常见的是BEM,当然还有OOCSS等,在构建工具出现之前,大多数都是在CSS命名上做文章

  2、CSS in JS

  彻底抛弃CSS,用javascript来写CSS规则,常见的有styled-components

  3、使用JS来管理样式

  使用JS编译原生的CSS文件,使其具备模块化的能力,最常见的就是CSS Modules

  随着构建工具的兴起,越来越多的人开始使用后两者方案,书写CSS时,不用再特意地关心样式冲突问题。只需要使用约定的格式编写代码即可

 

写法

  下面来介绍CSS modules的写法

  在style标签中添加module属性,表示打开CSS-loader的模块模式

<style module>
.red {color: red;}</style>

  在模板中使用动态类绑定:class,并在类名前面加上'$style.'

<template><p :class="$style.red">This should be red</p>
</template>

  如果类名包含中划线,则使用中括号语法

<h4 :class="$style['header-tit']">类别推荐</h4>

  也可以使用数组或对象语法

    <p :class="{ [$style.red]: isRed }">Am I red?</p><p :class="[$style.red, $style.bold]">Red and bold</p>

  更复杂的对象语法

    <ul 
    :class="{[$style.panelBox]:true,[$style.transitionByPanelBox]:needTransition}"

  更复杂的数组语法

    <li:class="[$style['aside-item'],{[$style['aside-item_active']]:(i === index)}]"

 

配置

  css-loader关于CSS modules的默认配置如下

{modules: true,importLoaders: 1,localIdentName: '[hash:base64]'
}

  可以使用vue-loader的cssModules选项为css-loader进行自定义的配置

module: {rules: [{test: '\.vue$',loader: 'vue-loader',options: {cssModules: {localIdentName: '[path][name]---[local]---[hash:base64:5]',camelCase: true}}}]
}

 

keyframes

  使用CSS modules处理动画animation的关键帧keyframes,有一个非常重要的细节——动画名称必须先写

animation: move 1s;

  上面代码会被正确解析为

animation: p_vDKHdm1YxIlQZ4rG_08_1 1s;

  如果动画名称写在后面

animation: 1s move;

  代码会被解析为

animation: 1s :local(move);

 

http://www.lbrq.cn/news/1335061.html

相关文章:

  • 睢县网站制作公司/网络推广是做什么工作的
  • 个人免费建站的网站/怎样才能注册自己的网站
  • 无锡网站建设电话/如何创建个人网页
  • 网络诚信 网站应怎么做/焊工培训ppt课件
  • 西安千叶网站建设/站长域名查询工具
  • 做微信小程序哪个网站好/关于友谊的连接
  • 网站建设泽宇/举一个病毒营销的例子
  • dedese网站/福州seo代理计费
  • 做优惠卷网站倒闭了多少钱/北京网站建设公司大全
  • 温岭自适应网站建设/网站推广优化排名公司
  • 英语故事网站建设/公众号运营
  • wordpress前台登录注册/丹东网站seo
  • 公司做网站需要准备什么/百度网首页官网登录
  • 邯郸做移动网站多少钱/百度一下你就知道了百度
  • 网站模块标准版/得物app的网络营销分析论文
  • b2b网站推广排名/提供seo顾问服务适合的对象是
  • 视频做网站背景/seo推广系统排名榜
  • 黄冈网站建设效果/长沙seo网站推广
  • 重庆的推广网站/谷歌广告平台
  • 新网站做百度推广/深圳网站开发
  • 前端电商网站开发周期/seo网站排名优化软件
  • 17一起做网站app/广州seo技术外包公司
  • 网站后台模板如何使用/seo优化方案总结
  • 上海网站建设公司价格/怎么建立网站的步骤
  • 深圳网站制作公司流程/网络服务器价格
  • 最早做美食团购的网站/百度快照查询入口
  • 电影网站如何做seo优化/互联网平台公司有哪些
  • 江门网站优化经验/广告公司联系方式
  • 大连微信网站制作/今天刚刚的最新新闻
  • 做网站的qq兼职/山东企业网站建设
  • dag实现案例 02、实现简易版dag调度系统(基于01之上升级)
  • Ansible 基础到实操笔记
  • kafka 消费者组的概念是什么?它是如何实现消息的点对点和发布/订阅模式?
  • sqli-labs通关笔记-第42关 POST字符型堆叠注入(单引号闭合 手工注入+脚本注入两种方法)
  • 机器翻译:一文掌握序列到序列(Seq2Seq)模型(包括手写Seq2Seq模型)
  • Centos 用http ftp搭建本地yum源 保姆级教程