技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-13-1.使用...

共 2164字,需浏览 5分钟

 ·

2021-07-31 03:15

技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-13-1.使用sass工具搭建前台web端页面

技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-2.启动项目
技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-13-1.使用sass工具搭建前台web端页面
技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-13-2.sass工具的变量
技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-13-3.使用flex布局并开始搭建web端
技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-13-4.vue广告轮播图,并使用接口引入数据
技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-13-5.使用字体图标(iconfont)
技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-13-6.卡片组件的封装
技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-14-1.生产环境编译
技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-vue.js devtools谷歌插件下载与安装

关于sass:

Sass 是一款强化 CSS 的辅助工具,它在 CSS 语法的基础上增加了变量 (variables)、嵌套 (nested rules)、混合 (mixins)、导入 (inline imports) 等高级功能,这些拓展令 CSS 更加强大与优雅。使用 Sass 以及 Sass 的样式库(如 Compass)有助于更好地组织管理样式文件,以及更高效地开发项目。
点击链接可进入sass官网

文件后缀是.scss,在此之前我们先一步一步对页面进行样式测试。

1.进入web端
cd web
npm run serve

a9b0225e7887080ad3ba1409dd15328b.webp
如果admin端已经开启8080端口,再开启web端就是8081端口了。
efa22e4bae27722ac9a27115cc6fa2ad.webp
此时我们在web文件夹中添加style.css文件,设置页面样式:
da3a1e6b9cf55acf652090e040ec7daa.webp
再到main.js引入该页面样式文件:
8248ad50d71c35257ba3768a22066ae5.webp
页面发生了变化,效果样式css的引入没问题:
1b2f94a838d2dc113eeaafb67feb6e6c.webp

2.安装sass

(1)我们先把style.css文件后缀改为.scss,然后main.js同样对引入的style文件进行修改:
ea898a634f80060e68a60aed26d4de6e.webp
此时页面报错,说在web端文件中找不到sass-loader:8cfe76580942396af208177e6b1b1db7.webp
(2)我们安装sass-loader:

cd web
npm i -D sass-loader

由于sass是强化css的辅助工具,所以只在我们开发时使用sass,待我们项目完成上线时sass就没有任何作用了。所以我们使用-D在生产环境安装。

-D即–dev(生产)
包名会被注册在package.json的devDependencies里面,仅在开发环境下存在的包用-D,如babel,sass-loader这些解析器

9420bbf0420bf6442b9373cbca42c214.webp
可惜,可惜,无论如何都安装不成功:)想尽一切办法
最终,我简单粗暴地安装了cnpm,使用cnpm下载了node-sass和sass-loader,原因是sass-loader依赖于node-sass,npm都下载不成功,大家如果npm下载不成功也可以使用cnpm:

npm i cnpm
cnpm i node-sass -d
cnpm i sass-loader -d

dc8b30a3658bf9852dea7aac624d00dd.webp
可能是由于淘宝当时引入的cnpm库中的sass-loader没有被更新,好像sass安装后来被官方改为只能由ruby安装等原因,但是不深究,我们得到结果就好。
2181c54e51008758ea50ab9108e02979.webp
安装sass-loader成功之后,页面发生了变化:
426f7fe2e422b8d2bdaa392f88d37aff.webp
应该是sass-loader版本号太高所致,此时vue-cli中使用到的webpack不能使用版本过高的sass-loader,所以我们下载7.3.1版本:

cnpm install sass-loader@7.3.1 -D

6a50b83f15cd1940ac2961ae25a2a345.webp
重新进入web端
ctrl + c
y回车

npm run serve

进入后页面再次发生变化,此时显示node-sass版本过高,让我们使用4.0.0版本:
41c63bd2c9f9f57cc8f7d591b1838135.webp
这时我们卸载之前版本的node-sass,安装4.0.0版本

cnpm uninstall node-sass
cnpm i node-sass@4.14.1 -d

安装完成后,再次重启web端。此时页面正常进入:
1b2f94a838d2dc113eeaafb67feb6e6c.webp

3.使用sass

因为sass是css工具,所以.scss文件可以使用css一切样式,这时我们测试第一个功能——嵌套。
首先我们修改当前vue页面元素:
ec034e810ee957e59fd80ad463f56416.webp
c051b15609cfbfe4ccf01a6441cfe1b5.webp
这时我们使用嵌套方法:
就像html语言中的嵌套元素一样,把元素按父子级嵌套。

p{
color:red;
}
.a{
background:red;
p
{
color: blue;
}
}

84e88ec2ec4f73d5c41216462b60ef91.webp

4.总结

sass的优势:sass通过变量 (variables)、嵌套 (nested rules)、混合 (mixins)、导入 (inline imports) 等高级功能,增加了效果样式css的复用性、美观性和易读性。
接下来的文章中我们就会使用sass编辑前端样式,一起学习sass除嵌套以外的其他功能。

更多设计、功能的学习经验,大家也可以去我的公众号查看!

————


浏览 43
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报