在weex中愉快的使用scss的方法步驟
weex 是一個(gè)可以利用 vue 或者 Rax 編寫(xiě)跨平臺(tái)手機(jī)應(yīng)用的框架。為了讓在 weex 有更好的樣式編寫(xiě)體驗(yàn),遂有了以下的方案。
1.初始化一個(gè) weex 工程
npm install weex-toolkit -g weex create weex-test cd weex-test npm run start
這時(shí)候就可以在瀏覽器看到界面了
2.接著為了可以在vue里面寫(xiě)scss, 我們需要安裝兩個(gè)東西, sass-loader、node-sass
npm install -D sass-loader@7.3.1 node-sass
在這里要注意一點(diǎn)sass-loader要安裝 7 版本的,不然會(huì)報(bào)錯(cuò),這是因?yàn)閟ass版本高導(dǎo)致的,接下來(lái)就可以愉快的寫(xiě)scss,還要注意一點(diǎn)需要在style標(biāo)簽加上語(yǔ)言標(biāo)記scss
<style lang="scss"> </style>
3.為了更好的組織項(xiàng)目結(jié)夠和樣式的統(tǒng)一,我們會(huì)把一些主題顏色、字體大小、文字顏色提取到一個(gè)scss文件,我們把它命名為variable.scss如下:
$theme-color: blue; $font-big: 32px; $font-nor: 28px; $font-small: 24px;
我們把它放到項(xiàng)目的src/common/scss下, 需要的時(shí)候就在vue文件中引用, 比如在 index.vue 頁(yè)面引用
<style lang="scss"> @import './common/scss/variable.scss' div { background-color: $theme-color; } </style>
這樣就可以讓?xiě)?yīng)用的主體部分的樣式保持一致了。
4.在 weex 中有一些屬性不支持簡(jiǎn)寫(xiě)的方式比如 border,還有一些需要寫(xiě)兩三條的樣式如文字超出隱藏,這種樣式我們可以將它們定義成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; }
我們把它放到項(xiàng)目的src/common/scss下, 需要的時(shí)候就在vue文件中引用, 比如在 index.vue 頁(yè)面引用
<style lang="scss"> @import './common/scss/variable.scss'; @import './common/scss/mixins.scss'; div { @include border(1px, solid, $theme-color); } </style>
這樣我們就可以將一些常用的css代碼寫(xiě)進(jìn)混合宏了
5.在weex中由于不支持類(lèi)名的權(quán)重覆蓋,只支持后面的定義的同類(lèi)樣式覆蓋前面的樣式,這樣就會(huì)導(dǎo)致我們不能很好的組織 css 代碼, 又不能利用 scss 的優(yōu)勢(shì)代碼層級(jí)嵌套。為此我們引入BEM命名方法,并通過(guò)scss的混合宏讓其在寫(xiě)法上支持嵌套,首先我們?cè)?src/common/scss 下創(chuàng)建 bem.scss,并寫(xiě)入如下代碼:
$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不支持層級(jí)所以我們只能用@at-root將所有類(lèi)名提升到第一層。接著我們?cè)趇ndex.vue中引入這個(gè)文件:
<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; }
這樣看起來(lái)用scss的寫(xiě)法代碼的結(jié)構(gòu)性和可維護(hù)性就會(huì)更好一些。
6.由于這三個(gè)文件都是需要在每一個(gè)vue文件引入的,為了偷一下懶,我們可以用sass-resources-loader 這個(gè)loader來(lái)讓每一個(gè)vue文件都注入這幾個(gè)scss文件
npm install -D sass-resources-loader
然后修改根目錄下的 configs/utils.js ,找到如下,進(jìn)行更改
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工程中愉快的編寫(xiě)scss了
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:JS實(shí)現(xiàn)旋轉(zhuǎn)木馬輪播圖
欄 目:JavaScript
本文標(biāo)題:在weex中愉快的使用scss的方法步驟
本文地址:http://mengdiqiu.com.cn/a1/JavaScript/9329.html
您可能感興趣的文章
- 01-10在Vue項(xiàng)目中使用Typescript的實(shí)現(xiàn)
- 01-10Vuex實(shí)現(xiàn)數(shù)據(jù)共享的方法
- 01-10推薦幾個(gè)不錯(cuò)的console調(diào)試技巧實(shí)現(xiàn)
- 01-10在JavaScript中實(shí)現(xiàn)鏈?zhǔn)秸{(diào)用的實(shí)現(xiàn)
- 01-10繼承行為在 ES5 與 ES6 中的區(qū)別詳解
- 01-10vue遠(yuǎn)程加載sfc組件思路詳解
- 01-10使用pkg打包ThinkJS項(xiàng)目的方法步驟
- 01-10vue項(xiàng)目中在可編輯div光標(biāo)位置插入內(nèi)容的實(shí)現(xiàn)代碼
- 01-10微信小程序wxs實(shí)現(xiàn)吸頂效果
- 01-10如何在Node和瀏覽器控制臺(tái)中打印彩色文字


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02javascript點(diǎn)線(xiàn),點(diǎn)線(xiàn)的代碼
- 04-02javascript潛力,javascript強(qiáng)大嗎
- 04-02javascript替換字符串,js字符串的替換
- 04-02javascript移出,js 移入移出
- 04-02包含javascript舍的詞條
- 04-02javascript并行,深入理解并行編程 豆瓣
- 04-02javascript匿名,js匿名方法
- 04-02javascript警報(bào),JavaScript警告
- 04-02javascript遮蓋,JavaScript遮蓋PC端頁(yè)面
- 04-02javascript前身,javascript的前身
隨機(jī)閱讀
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?