您好,登錄后才能下訂單哦!
1.安裝sass的依賴包
npm install --save-dev sass-loader
//sass-loader依賴于node-sass npm install --save-dev node-sass
2.在build文件夾下的webpack.base.conf.js的rules里面添加配置,如下紅色部分
{ test: /\.sass$/, loaders: ['style', 'css', 'sass'] }
<span >// module用來解析不同的模塊 module: { rules: [ ...(config.dev.useEslint ? [createLintingRule()] : []), { test: /\.vue$/, // 也就是說,對.js和.vue文件在編譯之前進行檢測,檢查有沒有語法錯誤'eslint-loader' // enforce: 'pre'選項可以確保,eslint插件能夠在編譯之前檢測,如果不添加此項,就要把這個配置項放到末尾,確保第一個執行 // 對vue文件使用vue-loader,該loader是vue單文件組件的實現核心,專門用來解析.vue文件的 loader: 'vue-loader', // 將vueLoaderConfig當做參數傳遞給vue-loader,就可以解析文件中的css相關文件 options: vueLoaderConfig }, { test: /\.js$/, // 對js文件使用babel-loader轉碼,該插件是用來解析es6等代碼 loader: 'babel-loader', // 指明src和test目錄下的js文件要使用該loader include: [resolve('src'), resolve('test')] }, { test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, // 對圖片相關的文件使用 url-loader 插件,這個插件的作用是將一個足夠小的文件生成一個64位的DataURL // 可能有些老鐵還不知道 DataURL 是啥,當一個圖片足夠小,為了避免單獨請求可以把圖片的二進制代碼變成64位的 // DataURL,使用src加載,也就是把圖片當成一串代碼,避免請求,神不神奇?? loader: 'url-loader', options: { // 限制 10000 個字節一下的圖片才使用DataURL limit: 10000, name: utils.assetsPath('img/[name].[hash:7].[ext]') } }, { test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/, // 字體文件處理,和上面一樣 loader: 'url-loader', options: { limit: 10000, name: utils.assetsPath('media/[name].[hash:7].[ext]') } }, { test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/, loader: 'url-loader', options: { limit: 10000, name: utils.assetsPath('fonts/[name].[hash:7].[ext]') } }, </span><span >{ test: /\.sass$/, loaders: ['style', 'css', 'sass'] }</span><span > ] },</span>
3.修改模板里面的style lang="scss";例如模板紅色標記
<style lang="scss">
<template> <div id="indexContent"> <v-header></v-header> <div class="tab"> <div class="tab-item"> <!-- 使用 router-link 組件來導航. --> <!-- 通過傳入 `to` 屬性指定鏈接. --> <!-- <router-link> 默認會被渲染成一個 `<a>` 標簽 --> <router-link to="/foods">商品</router-link> </div> <div class="tab-item"> <router-link to="/rating">評論</router-link> </div> <div class="tab-item"> <router-link to="/seller">商家</router-link> </div> </div> <!-- 路由出口 --> <!-- 路由匹配到的組件將渲染在這里 --> <router-view></router-view> </div> </template> <script type="text/ecmascript-6"> import header from './components/header/header.vue'; // 加default表示對整個模塊進行導出 export default{ components: { 'v-header': header } }; </script> <span ><style lang="scss"></span> #indexContent { .tab{ display: flex; width:100%; height: 40px; line-height: 40px; .tab-item { flex: 1; text-align: center; a{ display:block; } } } } </style>
4.npm run dev
5.效果
以上這篇基于vue中css預加載使用sass的配置方式詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。