摘要:你还需安装一个依赖,告诉使用者,你这个是基于哪个版本开发的,当然你可以不安装这个依赖,那只能自己用了。开发调试在根目录中运行在本机全局为做一个软链接,如果你移动了目录你得重新做软链接。因为你在前面添加了文件事实上导入的文件是。
由于Stylus的强大,它支持SCSS LESS 灵活的书写方式,然后它不用像SCSS安装Ruby,不是特别出名,流行的工具没有使用它,只是在小的圈子里面挺火滴。它的强大不用赘述了,我正在使用了它开始吧:最近为了方便自己将px转换成rem写了一个基于Stylus的插件,我就以它为例子吧,源码在此stylus-px2rem
准备工作你本机需要安装node,现在我假设你已经安装好了node,建立好你的文件,这个是我的文件目录,我将插件stylus-px2rem项目放在我本机的这个位置~/git/stylus-px2rem
stylus-px2rem # 项目根目录 ├── README.md ├── index.styl # px2rem入口文件 ├── lib │ ├── px2rem.js # 这个很重要下面详细描述 │ ├── stylus-px2rem # Stylus插件需要的文件 │ │ ├── mixins.styl │ │ ├── padding.styl │ │ ├── width.styl │ │ .... │ └── stylus-px2rem.styl # 同样是px2rem的入口文件 ├── node_modules # 依赖包其实可以啥包也不用 └── package.json # 配置文件添加基础的文件 添加配置文件
你可以通过npm init 一路Enter生成package.json基本标准的配置文件。你还需安装一个Stylus依赖,告诉使用者,你这个是基于Stylus哪个版本开发的,当然你可以不安装这个依赖,那只能自己用了。
{ "name": "stylus-px2rem", "version": "1.0.4", "description": "Stylus convert px to rem in css files with optional fallback to px.", "main": "lib/px2rem.js", "scripts": { "test": "echo "Error: no test specified" && exit 1" }, "repository": { "type": "git", "url": "https://github.com/jaywcjlove/stylus-px2rem" }, "keywords": [], "author": "kenny wang <398188662@qq.com>", "license": "MIT", "dependencies": { "stylus": "^0.54.2" } }
这个配置文件package.json要注意添加一个 "main": "lib/px2rem.js" 这个很重要它指明你在使用这个包的一个根目录,这个是在你使用Stylus的use方法必须要的js文件方便你找到你的styl文件。lib/px2rem.js 代码
var plugin = module.exports = function plugin () { "use strict"; return function (style) { style.include(__dirname); }; }; plugin.path = __dirname; plugin.version = require(__dirname + "/../package.json").version;
添加了这个js文件,你放在什么目录在你使用这个插件,在styl文件中引入的路径就变更了,你使用@import "stylus-px2rem" 的最终路径是px2rem.js所在的项目绝对路径,因为我是放在lib目录中,所以路径为绝对路径/stylus-px2rem/lib/stylus-px2rem.styl。如果你不需要这个js文件很多时候会因为找不到你引入的styl文件而报错。
添加预处理文件我们将预处理文件全部放到./lib/stylus-px2rem目录下名字跟包名字一样,这样方便你引入这个styl处理工具的时候保持一模一样的名字。同样你还需要建立一个stylus-px2rem.styl文件,其实这个是一个类似于软链接一样的,跟放在根目录的index.styl文件是一样的。
在index.styl 里面的类容是导入lib文件夹中的stylus-px2rem.styl 文件
@import "lib/stylus-px2rem.styl"
在stylus-px2rem.styl里面是导入你要与处理CSS的styl文件。
@import "stylus-px2rem/mixins" @import "stylus-px2rem/font-size" //...
文件建立好之后你就可以很方便的使用stylus-px2rem 工具了。
开发调试在stylus-px2rem根目录中运行npm link在本机全局为stylus-px2rem做一个软链接,如果你移动了stylus-px2rem目录你得重新做软链接。输出下面内容你就可以在你的项目中调试使用了。
/usr/local/lib/node_modules/stylus-px2rem -> ~/git/stylus-px2rem
你只需在你需要使用的项目中运行npm link stylus-px2rem在你的项目只再做一次软链你就可以编辑你的插件,在你的项目中调试了。
项目中使用 在 Gulp 中使用新建 gulpfile.js 文件在stylus的use参数对象使用stylus-px2rem
var gulp = require("gulp"); var stylus = require("gulp-stylus"); var px2rem = require("stylus-px2rem"); gulp.task("stylus",function(){ gulp.src("./styl/*.styl") .pipe(stylus({ use:[px2rem()], compress:true })) .pipe(gulp.dest("./build")); })
在index.styl 中使用
@import "stylus-px2rem" .banner{ height 140px font-size 24px }
在你做好配置之后你就可以跑你建立的gulp任务命令:gulp stylus
在 npm script 构建使用首先安装 Stylus 工具,再安装stylus-px2rem
$ npm install stylus --save
如果没有发布调试过程,或者不打算发布,确定安装上面步骤做好全局软链了,你只需要在你使用的项目中做一次软链就可以了。
$ npm link stylus-px2rem
如果你不需要调试,直接将stylus-px2rem发布到npmjs.org上面了就运行下面命令。
$ npm install stylus-px2rem --save
然后在你的package.json中添加scripts 就可以了
{ "scripts": { "build": "stylus -u stylus-px2rem index.styl -o css/ -c", "watch": "stylus -u stylus-px2rem -w "index.styl" -o css/ -c " }, "dependencies": { "stylus": "^0.54.2", "stylus-px2rem": "^1.0.4" } }
然后在你的styl文件中引用即可,因为你上面的命令中使用了-u stylus-px2rem工具,所以你只需在index.styl中简单倒入即可。
@import "stylus-px2rem"
因为你在前面添加了lib/px2rem.js文件事实上@import导入的文件是~/git/stylus-px2rem/lib/stylus-px2rem.styl。
在你的项目中添加好了之后你可以运行命令编译或者监控自动编译。
# 监控文件实时编译CSS文件 $ npm run watch # 直接编译生成CSS文件 $ npm run build最简单的使用
假设你stylus工具是全局安装的
npm install -g stylus # 全局安装stylus npm link stylus-px2rem # 调试的方法安装到当前目录
建立你的index.styl文件并使用stylus-px2rem。
/* 这种引用方式是你在目录lib/px2rem.js指向了lib目录,所以直接引用的是stylus-px2rem.styl文件 */ @import "stylus-px2rem" /* 这种方式是lib/px2rem.js指向了这个目录,你引用stylus-px2rem目录中的styl文件 */ @import "stylus-px2rem/mixins" @import "stylus-px2rem/font-size" @import "stylus-px2rem/border" @import "stylus-px2rem/margin" div{ width:30px }
运行命令输出CSS文件:
$ stylus -u stylus-px2rem index.styl
你的styl可以这样引用stylus-px2rem处理文件
@import "node_modules/stylus-px2rem/lib/stylus-px2rem"
也可以一个一个的引用
@import "node_modules/stylus-px2rem/lib/stylus-px2rem/mixins" @import "node_modules/stylus-px2rem/lib/stylus-px2rem/font-size" @import "node_modules/stylus-px2rem/lib/stylus-px2rem/border" @import "node_modules/stylus-px2rem/lib/stylus-px2rem/margin" @import "node_modules/stylus-px2rem/lib/stylus-px2rem/padding" @import "node_modules/stylus-px2rem/lib/stylus-px2rem/width" @import "node_modules/stylus-px2rem/lib/stylus-px2rem/height" @import "node_modules/stylus-px2rem/lib/stylus-px2rem/line-height"
关注公众号
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/115192.html
摘要:为何选择压缩编译单元测试代码检查等我们需要自动化,不必重复劳动,减小工作量。用于保存项目元数据。图像压缩模块。监视文件变动,做出相应动作。 为何选择Grunt? 压缩、编译、单元测试、代码检查等 我们需要自动化,不必重复劳动,减小工作量。为何选择Grunt呢?好像是没有更好的选择了。 准备工作 安装node.js Grunt基于Node.js,安装之前要先安装No...
摘要:默认使用的作为文件扩展名,支持多样性的语法。功能上更为强壮,和联系更加紧密。所以我选择,玩儿过一段时间,主要是这玩意依赖运行,所以我放弃使用了。这样就算是安装完了,也可以正常使用。用于保存项目元数据。 stylus介绍 是个什么鬼?对于开发来说,CSS的弱点在于静态化。我们需要一个真正能提高开发效率的工具,LESS, SASS都在这方面做了一些贡献。 Stylus 是一个CSS的预...
摘要:介绍是一个的预处理框架,年产生,来自社区,主要用来给项目进行预处理支持,所以是一种新型语言,可以创建健壮的动态的富有表现力的。 stylus介绍 Stylus 是一个CSS的预处理框架,2010年产生,来自Node.js社区,主要用来给Node项目进行CSS预处理支持,所以 Stylus 是一种新型语言,可以创建健壮的、动态的、富有表现力的CSS。比较年轻,其本质上做的事情与 SASS...
摘要:介绍是一个的预处理框架,年产生,来自社区,主要用来给项目进行预处理支持,所以是一种新型语言,可以创建健壮的动态的富有表现力的。 stylus介绍 Stylus 是一个CSS的预处理框架,2010年产生,来自Node.js社区,主要用来给Node项目进行CSS预处理支持,所以 Stylus 是一种新型语言,可以创建健壮的、动态的、富有表现力的CSS。比较年轻,其本质上做的事情与 SASS...
平日学习接触过的网站积累,以每月的形式发布。2017年以前看这个网址:http://www.kancloud.cn/jsfron... 1. Javascript 前端生成好看的二维码 十大经典排序算法(带动图演示) 为什么知乎前端圈普遍认为H5游戏和H5展示的JSer 个人整理和封装的YU.js库|中文详细注释|供新手学习使用 扩展JavaScript语法记录 - 掉坑初期工具 汉字拼音转换...
阅读 994·2023-04-26 02:26
阅读 2029·2021-09-26 10:16
阅读 1488·2019-08-30 12:57
阅读 3392·2019-08-29 16:10
阅读 3136·2019-08-29 13:47
阅读 1115·2019-08-29 13:12
阅读 2062·2019-08-29 11:11
阅读 1271·2019-08-26 13:28