时间:2021-05-25
weex 是一个可以利用 vue 或者 Rax 编写跨平台手机应用的框架。为了让在 weex 有更好的样式编写体验,遂有了以下的方案。
1.初始化一个 weex 工程
npm install weex-toolkit -gweex create weex-testcd weex-testnpm run start这时候就可以在浏览器看到界面了
2.接着为了可以在vue里面写scss, 我们需要安装两个东西, sass-loader、node-sass
npm install -D sass-loader@7.3.1 node-sass在这里要注意一点sass-loader要安装 7 版本的,不然会报错,这是因为sass版本高导致的,接下来就可以愉快的写scss,还要注意一点需要在style标签加上语言标记scss
<style lang="scss"></style>3.为了更好的组织项目结够和样式的统一,我们会把一些主题颜色、字体大小、文字颜色提取到一个scss文件,我们把它命名为variable.scss如下:
$theme-color: blue;$font-big: 32px;$font-nor: 28px;$font-small: 24px;我们把它放到项目的src/common/scss下, 需要的时候就在vue文件中引用, 比如在 index.vue 页面引用
<style lang="scss">@import './common/scss/variable.scss'div { background-color: $theme-color;}</style>这样就可以让应用的主体部分的样式保持一致了。
4.在 weex 中有一些属性不支持简写的方式比如 border,还有一些需要写两三条的样式如文字超出隐藏,这种样式我们可以将它们定义成scss的混合宏(mixin),我们把它命名为mixins.scss
@mixin border($width, $style, $color) { border-width: $width; border-style: $style; border-color: $color;}@mixin border-top($width, $style, $color) { border-top-width: $width; border-top-style: $style; border-top-color: $color;}我们把它放到项目的src/common/scss下, 需要的时候就在vue文件中引用, 比如在 index.vue 页面引用
<style lang="scss">@import './common/scss/variable.scss';@import './common/scss/mixins.scss';div { @include border(1px, solid, $theme-color);}</style>这样我们就可以将一些常用的css代码写进混合宏了
5.在weex中由于不支持类名的权重覆盖,只支持后面的定义的同类样式覆盖前面的样式,这样就会导致我们不能很好的组织 css 代码, 又不能利用 scss 的优势代码层级嵌套。为此我们引入BEM命名方法,并通过scss的混合宏让其在写法上支持嵌套,首先我们在 src/common/scss 下创建 bem.scss,并写入如下代码:
$namespace: '';$element-separator: '__';$modifier-separator: '--';@mixin b($block) { @if $namespace == '' { $B: $block !global; } @else { $B: $namespace+'-'+$block !global; } @if '#{&}' == '' { .#{$B} { @content; } } @else { @at-root { .#{$B} { @content; } } }}@mixin e($element) { $E: $element !global; $selector: &; @if str-index('#{&}', '__') { @at-root { .#{$B + $element-separator + $element} { @content; } } } @else { @at-root { #{&+$element-separator+$E} { @content; } } }}@mixin m($modifier) $M: $modifier !global; @at-root { #{&+$modifier-separator+$M} { @content; } }}由于weex不支持层级所以我们只能用@at-root将所有类名提升到第一层。接着我们在index.vue中引入这个文件:
<template> <div class="header"> <div :class="['header__back', `header__back--${status}`]"></div> <div class="header__content"></div> <div class="header__other"></div> </div></template><script>export default { data(){ return { status: 'black' } }}</script><style lang="scss">@import './common/scss/variable.scss';@import './common/scss/mixins.scss';@import './common/scss/bem.scss'@include b('header') { height: 100px; width: 750px; flex-direction: row; align-items: center; @include e('back') { flex: 1; @include m('black') { background-color: #000000; } @include m('white') { background-color: #ffffff; } } @include e('content') { flex: 3; } @include e('other') { flex: 1; }}</style>编译后的样式为:
.header { height: 100px; width: 750px; flex-direction: row; align-items: center;}.header__back { flex: 1;}.header__back--black { background-color: #000000;}.header__back--white { background-color: #ffffff;}.header__content { flex: 3;}.header__other { flex: 1;}这样看起来用scss的写法代码的结构性和可维护性就会更好一些。
6.由于这三个文件都是需要在每一个vue文件引入的,为了偷一下懒,我们可以用sass-resources-loader 这个loader来让每一个vue文件都注入这几个scss文件
npm install -D sass-resources-loader然后修改根目录下的 configs/utils.js ,找到如下,进行更改
const generateLoaders = (loader, loaderOptions) => { let loaders = options.useVue ? [cssLoader] : [] if (options.usePostCSS) { loaders.push(postcssLoader) } if (loader) { loaders.push({ loader: loader + '-loader', options: Object.assign({}, loaderOptions, { sourceMap: options.sourceMap }) }) } //这里加入以下代码 if (loader === 'sass') { loaders.push({ loader: 'sass-resources-loader', options: { resources: [ path.resolve(__dirname, '../src/common/scss/variable.scss'), path.resolve(__dirname, '../src/common/scss/mixins.scss'), path.resolve(__dirname, '../src/common/scss/bem.scss') ] } }) } if (options.useVue) { return ['vue-style-loader'].concat(loaders) } else { return loaders } }这样就可以在weex工程中愉快的编写scss了
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Weex简介Weex是阿里前端技术团队开源额一套跨平台开发方案,能以web的开发体验构建高性能、可扩展的native应用,Weex的页面表示层使用Vue,并遵循
本文主要介绍了Vue+scss白天和夜间模式切换功能的实现方法,分享给大家,具体如下:效果图图片被压缩了不够清晰。安装Scss注:若安装失败可以考虑使用cnpm
简述最近由于项目要求查阅了很多关于scss公用的文章,以下只是对那些文章进行简单的总结解决方法a.当我们要使用scss文件的共用时,首先我们就要想到如何应当如何
一、在vue中使用scss首先进行安装如下依赖:cnpmisass-loadernode-sass-D二、vue中引入样式文件1)在index.html模板ht
本节课讲解在webpackv4中的SCSS提取和懒加载。值得一提的是,v4和v3在Scss的懒加载上的处理方法有着巨大差别。>>>本节课源码>>>所有课程源码1