stylus css 架构应用方式深层次分析

2021-01-20 06:13 jianzhan

Stylus是1款必须编译程序的css語言,因此其自身文档不可以被html立即启用,必须要编译程序为css文档后再开展平常的载入。

stylus是1款出色的css编译程序語言,必须node.js适用,第1步必须安裝node.js

难题:Windows调节时ctrl+d失效果 ctrl+c撤出? 如何立即在windows下輸出调节编码

备注:# 意味着本行是键入回车运作行

官网免费下载nodejs

XML/HTML Code拷贝內容到剪贴板
  1. tar xvf node-v0.10.28.tar.gz    
  2. #  cd node-v0.10.28    
  3. #  ./configure    
  4. # make    
  5. # make install    
  6. # cp /usr/local/bin/node /usr/sbin/  

 2 node - v 查询node版本号信息内容假如有回到信息内容则安裝取得成功

3 安裝stylus

# npm install stylus -g留意:务必找-g 另外配备自然环境为全局性方式

4 调节Stylus

CSS Code拷贝內容到剪贴板
  1. # stylus   
  2. border-radius()   
  3.   -webkit-border-radius arguments   
  4.   -moz-border-radius arguments   
  5.   border-radius arguments   
  6.      
  7. body   
  8.   font 12px HelveticaArialsans-serif  
  9.      
  10. a.button   
  11.   border-radius(5px)  

键入Ctrl+D调节回到結果

看看是不是会回到

CSS Code拷贝內容到剪贴板
  1. body {   
  2.   font12px HelveticaArialsans-serif;   
  3. }   
  4. a.button {   
  5.   -webkit-border-radius: 5px;   
  6.   -moz-border-radius: 5px;   
  7.   border-radius: 5px;   
  8. }  

5 styus文档的编译程序

建立1个test.styl 的文档,文档內容以下:

CSS Code拷贝內容到剪贴板
  1. border-radius()   
  2.   -webkit-border-radius arguments   
  3.   -moz-border-radius arguments   
  4.   border-radius arguments   
  5.      
  6. body   
  7.   font 12px HelveticaArialsans-serif  
  8.      
  9. a.button   
  10.   border-radius 5px  

储存关掉,在指令行运作以下指令:

# stylus --compress < test.styl > test.css

看看是否得到1个test.css的文档,看看內容是不是以下:

CSS Code拷贝內容到剪贴板
  1. body{   
  2. font:12px Helvetica,Arial,sans-serif  
  3. }   
  4. a.button{   
  5. -webkit-border-radius:5px;   
  6. -moz-border-radius:5px;   
  7. border-radius:5px  
  8. }  

这样1个stylus的文档就被编译程序变成html能够启用的css文档了。

 附录:

编译程序文档案例
stylus亦接纳文档和文件目录。比如,1个文件目录名为css将在同1文件目录编译程序并輸出.css文档。

$ stylus css下面的可能輸出到./public/stylesheets:

$ stylus css --out public/stylesheets或1些文档:

$ stylus one.styl two.styl以便开发设计的目地,你可使用linenos选项传出命令在转化成的CSS中显示信息Stylus文档名和行数。

$ stylus --line-numbers <path>或是firebug选项,假如你想应用firebug的FireStylus拓展。

$ stylus --firebug <path>变换CSS
假如你想把CSS变换成简约的Stylus英语的语法,可使用--css标示。

根据规范键入輸出:

$ stylus --css < test.css > test.styl輸出基础名1致的.styl文档。

$ stylus --css test.css輸出特殊的总体目标:

$ stylus --css test.css /tmp/out.stylCSS特性的协助
在OS X上,stylus help <prop>会开启你默认设置访问器并显示信息给定的<prop>特性的协助文本文档。

$ stylus help box-shadow壳层互动(Interactive Shell)
Stylus REPL (Read-Eval-Print-Loop)或“壳层互动(Interactive Shell)”容许你立即在终端设备机上盘玩Stylus的表述式。

留意仅有表述式能够起效,而并不是挑选器之类。以便简易,大家加上-i或--interactive标示:

$ stylus -i
> color = white
=> #fff
> color - rgb(200,50,0)
=> #37cdff
> color
=> #fff
> color -= rgb(200,50,0)
=> #37cdff
> color
=> #37cdff
> rgba(color, 0.5)
=> rgba(55,205,255,0.5)运用软件
本例大家将应用nibStylus软件来讲明它的CLI应用。

假定大家有以下的Stylus, 其导入nib并应用nib的linear-gradient()方式:

@import 'nib'

body
  background: linear-gradient(20px top, white, black) 大家是应用stylus(1)根据规范键入輸出尝试3D渲染的第1个物品将会就像下面这样:

$ stylus < test.styl这将会会转化成以下的不正确,由于Stylus不知道道去哪里寻找nib.

Error: stdin:3
    1|
    2|
  > 3| @import 'nib'
    4|
    5| body
    6|   background: linear-gradient(20px top, white, black)针对简易运用Stylus API们的软件,大家能够加上搜索相对路径。根据应用--include或-I标示:

$ stylus < test.styl --include ../nib/lib如今转化成內容以下。您将会留意到了,gradient-data-uri()和create-gradient-image()以字面量方式輸出了。这是由于,当软件出示JavaScript API的情况下,光曝露软件的相对路径是不足的。可是,假如大家仅仅要想的是纯碎Stylus nib涵数,则充足了。

CSS Code拷贝內容到剪贴板
  1. body {   
  2.   backgroundurl(gradient-data-uri(create-gradient-image(20pxtop)));   
  3.   background: -webkit-gradient(linear, left topleft bottombottomcolor-stop(0, #fff), color-stop(1, #000));   
  4.   background: -webkit-linear-gradient(top#fff 0%, #000 100%);   
  5.   background: -moz-linear-gradient(top#fff 0%, #000 100%);   
  6.   background: linear-gradient(top#fff 0%, #000 100%);   
  7. }  

因而,大家必须做的是应用--use或-u标示。其会寻找node控制模块(有或沒有.js拓展名)相对路径,这里的require()控制模块或启用style.use(fn())来曝露该软件(界定js涵数等)。

$ stylus < test.styl --use ../nib/lib/nib转化成为:

CSS Code拷贝內容到剪贴板
  1. body {   
  2.   backgroundurl("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAUCAYAAABMDlehAAAABmJLR0QA/wD/AP+gvaeTAAAAI0lEQVQImWP4+fPnf6bPnz8zMH358oUBwkIjKJBgYGNj+w8Aphk4blt0EcMAAAAASUVORK5CYII=");   
  3.   background: -webkit-gradient(linear, left topleft bottombottomcolor-stop(0, #fff), color-stop(1, #000));   
  4.   background: -webkit-linear-gradient(top#fff 0%, #000 100%);   
  5.   background: -moz-linear-gradient(top#fff 0%, #000 100%);   
  6.   background: linear-gradient(top#fff 0%, #000 100%);   
  7. }  

nodemon 软件

# npm install nodemon -g

JavaScript Code拷贝內容到剪贴板
  1. var css = require("stylus"),    
  2.     str = require("fs").readFileSync("style.styl""utf8");   
  3.        
  4. css.render(str, { filename: "stylus.styl" }, function(err, css) {   
  5.     if (err) throw err;   
  6.     var http = require('http');   
  7.     http.createServer(function (req, res) {   
  8.         res.writeHead(200, {'Content-Type''text/css'});   
  9.         res.end(css);   
  10.     }).listen(1337, '127.0.0.1');   
  11.     console.log('早已起动 http://127.0.0.1:1337/');   
  12. });  

以上这篇stylus css 架构应用方式深层次分析便是网编共享给大伙儿的所有內容了,期待能给大伙儿1个参照,也期待大伙儿多多适用脚本制作之家。