Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

more-css

Package Overview
Dependencies
Maintainers
1
Versions
73
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

more-css

a css pre-compiler & agressive compressor

  • 0.1.1
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
92
increased by557.14%
Maintainers
1
Weekly downloads
 
Created
Source

##A css pre-compiler by javascript

The css lexer bases on jssc: https://github.com/army8735/jssc

相对于less,more的命名意思是比原本的css多做了一点点,定位于普通产品简化开发位置,而非广义CSS下游框架重量级功能。

目前仅提供层级功能、子文件拆分和层级变量(实际上就是原标准的@import语法,并不擅自发明规范之外的新语法,合并工具请自行实现);还有css激进压缩器。

web目录下为书写符合AMD/CMD规范的js文件; server目录下为nodejs环境的module模块。

more的核心理念是:原有的浏览器标准不修改,编译后的代码严格保持调试一致,行数不变更,文件对应关系不改变,满足GoToDefine的先决条件。

##API

more.parse(code:String, preVars:Object):String

方法传入源代码,返回解析后的代码,如果出错,返回错误信息。 preVars为解析前预变量,功用在于实现层级变量作用域——即被import的文件可以访问父级变量。此接口可以自定义实现仅文件内作用域或全局作用域。 推荐使用层级作用域,demo文件夹中的import.html和node.js演示了这一特性。

more.tree():Node

获取解析后的语法树。此为内部接口,一般用不到。

more.token():Array

获取解析后的词法单元列表。此为内部接口,一般用不到。

more.vars():Object<String, String>

获取解析后的变量声明哈希表。键为变量名,值为变量值。

more.imports():Array

获取解析后的导入文件列表。

more.compress(src:String, agressive:Boolean):String

压缩css文件。此方法基于clean-css,在不传入agressive参数或为false时即为clean-css的原有压缩功能;agressive为true时进行激进压缩,合并去重聚合以及择优提取公因子,也是安全无冲突的。

激进压缩5个步骤:合并相同选择器merge、去除同一选择器中重复样式声明duplicate、去除同一选择器中被覆盖的样式声明override、聚合相同样式的选择器union、提取公因子extract。

License

[MIT License]

Keywords

FAQs

Package last updated on 12 Oct 2013

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc