Vue 中sass的基本操作

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue 中sass的基本操作相关的知识,希望对你有一定的参考价值。

参考技术A

我本地的vue-cli的版本 @vue/cli 4.3.1 ,这个版本脚手架创建的vue项目配置全局sass的时候需要在vue.config.js中指定 prependData 而不是 data ,具体不知道官网啥时候改动的。

创建全局的css文件common.scss,写一个变量。

页面中引用

common.scss文件中创建

使用

common.scss文件中创建

使用

如何在vue中使用sass

创建一个基于 webpack 模板的新项目

全局安装 vue-cli

$ npm install --global vue-cli

创建一个基于 webpack 模板的新项目

$ vue init webpack my-project

安装依赖

$ cd my-project
$ npm install

为了使用sass,我们需要安装sass的依赖包

npm install --save-dev sass-loader
//sass-loader依赖于node-sass
npm install --save-dev node-sass

修改style标签

打开src目录下的components目录中的Hello.vue文件。
然后修改 style标签如下

<style lang="sass">

然后运行项目  

npm run dev

终端显示错误,如下:  

ERROR  Failed to compile with 1 errors

 error  in ./src/components/Hello.vue

Module build failed: 
h1, h2 {
       ^
      Invalid CSS after "h1, h2 {": expected "}", was "{"
      in /Users/fangyongle/my-blogger/src/components/Hello.vue (line 36, column 9)

错误提示:无效的css。因为sass语法不使用大括号和分号。
如果你喜欢使用不带大括号的语法,只要去掉css代码的大括号和分号,即使用缩进语法。
如果你希望使用带大括号的语法,即SCSS
那么,你只要把lang="sass"改成lang="scss"就行了。  

引用sass/scss 文件

举个例子

@import  "./common/scss/mixin";

千万别忘了分号
否则会报错类似的错误  

Module build failed: 
  #app {
^
  Media query expression must begin with ‘(‘
  in /Users/fangyongle/elema/src/App.vue (line 35, column 1)
@ ./~/vue-style-loader!./~/css-loader!./~/vue-loader/lib/style-rewriter.js?id=data-v-0bf489db!./~/sass-loader!./~/vue-loader/lib/selector.js?type=styles&index=0!./src/App.vue 4:14-248 13:3-17:5 14:22-256  

完成

原文地址:http://www.jianshu.com/p/67f52071657d  

  

以上是关于Vue 中sass的基本操作的主要内容,如果未能解决你的问题,请参考以下文章

全局SASS/SCSS变量在Vue项目中应用解决方案

在Vue中使用sass及sass图片路径问题

在 .vue 文件中访问全局 sass 变量和引导程序

使用vue2.x+webpack+vuex+sass+axios+elementUI等快速搭建前端项目框架

vue-cli3使用sass全局变量(less同理)

vue-cli3使用sass全局变量(less同理)