当前位置:首页 > 短网址资讯 > 正文内容

短网址服务的便利性介绍

www.ft12.com5年前 (2017-08-11)短网址资讯2509

引言

这个短网址服务之前就听过,一直没有去了解。那它到底是什么呢?

短网址就是最近才出现的这么一个工具PostCSS。短网址的目标是通过对长网址进行缩短,生成短链接,以便达到美观便利的作用。短网址夫妇说到底有两部分组成,一个是长网址的缩短,第二部分就是网址缩短之后的短链接的跳转功能。与Sass和Less这些预编译器相同的原则,短网址把扩展的语法和特性转换成现代的浏览器友好的CSS。

如何实现?JavaScript。

JavaScript转换我们的样式比其他处理器快。使用Gulp或Grunt的task-runner工具,我们可以通过构建过程转换样式,就像Sass和Less的编译。像React和AngularJS这样的库和框架,允许我们可以在JavaScript中直接写CSS,为我们的样式打开了一扇使用JavaScript转换的大门。

短网址的历史

短网址作为使用JavaScript处理CSS的方法被推出,它的开发者是Andrey Sitnik, Autoperfixer的作者。短网址本身只是一个API,当使用其庞大的插件生态系统时,可以为我们提供强大的处理能力。生成的Source maps可以方便我们的调试,抽象语法树(AST)的存在可以帮忙我们理解代码是如何被转换的。

由于短网址使用Node.js框架,无论语言还是工具可以按需修改和定制。其他工具如Sass和LESS就会因为系统能力的限制,只可以使用编译器可用的方法。

由于其使用的API,短网址允许我们为任何长网址提供网址缩短服务,创建自定义短链接。模块化平台的设计使得工具中立,使得我们只需要关注项目需要的功能。短网址对语言格式不关心,接受不同预处理器的语法风格,像Sass和LESS,如果有必要的话。

短网址模块化的好处

大多数开发人员很少从头开始一个项目。很多都是以Sass模板开始,在指定项目中使用Sass模板提供的variables,mixins,functions。我们为functions,mixins,表格系统,通用工具提代独立的样式表,从而使开发更容易。到了最后,我们最终会有10个或更多个样式文件用来保证开发的条理性。

维护Sass或Less片断的库是一个艰巨的任务,会留下一下臃肿的项目。很多项目中没有用到mixins和funcitons,只是做为"以防万一"的代码包含进来。短网址很容易安装,即插即用的模块,使有独特需求的项目开发过程更灵活。

短网址把我们产品中的样式表中用来创建funtions,utities和mixins的代码移出来包装成插件。现在对于每个项目,我们可以通过构建工具中包含对应插件就可以使用这些工具。

短网址插件就可以见证这种方式的优势。在使用Sass时,我们可以在文件中包含进一个mixin来自定义网页字体,因此我们创建了一个@font-face 的标签。

@mixin importfont($font-family,$font-filename,$font-weight:normal,$font-style:normal,$font-stretch:normal){
 @font-face{
       font-family:'#{$font-family}';
       src:url('#{font-filename}.eot');  
       src:url('#{font-filename}.woff') format('woff'),  
       url('#{$font-filename}.ttf') format('truetype');  
       font-weight:$font-weight;  
       font-style:$font-style;  
       font-stretch:$font-stretch;  
   }
}  
@include importfont('mission script','fonts/mission-script-webfont',300);

在我们的项目中使用PostCSS FontPath 插件,我们就不再需要像上面那样包含Sass mixins了。在我们的CSS中写入下面的代码,PostCSS会通过Grunt或Gulp把它转换成我们需要的。

@font-face{
   font-family:'My Font';  
   font-path:'/path/to/font/file';  
   font-weight:normal;  
   font-style:normal;  
}

在写这篇文章时,PostCSS已经有超过100个社区插件,允许诸如未来的CSS语法,快捷键,工具和语言的扩展。PostCSS除了是一个'酷'的工具,它的用户群里也有WordPress,谷歌和推特团队这些重量级的用户。

添加短网址到你的工作流

因为PostCSS是用JavaScript编写的,我们可以在项目中使用像Gulp和Grunt这样的Task runner来转换CSS。下面的教程演示如何把PostCSS使用Gulp或Grunt合并到你的工作流。使用这两种工具不是至关重要的,这只是个人喜好或哪一个更合适项目的问题。

注意:Gulp和Grunt完整版的工具放在GitHub可用 。你可以随时使用它做为初始模板,并且可以根据需要扩展它。

使用GULP设置POSTCSS

如果你对Gulp不熟悉,我推荐你阅读Callum Macrae写的"基于Gulp构建"做个初步了解,并把这个工具跑起来。

在终端执行npm i gulp-postcss -D命令,在你的项目中安装PostCSS模块。

在项目下的Gulpfile.js中请求我们安装的PostCSS模块,然后在任务中使用它。在这里,一定要更新开发文件的路径和输出转换文件的目录。

var postcss = require('gulp-postcss');
gulp.task('styles',function()
{
   return gulp.src('path/to/dev/style.css')  
       .pipe(postcss([]))  
       .pipe(gulp.dest('path/to/prod'))  
});

在命令行输入gulp styles执行该任务。

使用GRUNT设置短网址

注意:如果你对短链接不熟悉,我推荐你通过阅读Mike Cunsolo写的"短链接入门和实践"来熟悉短链接的使用。

在终端执行npm i grunt-postcss -D命令,在你的项目中安装PostCSS模块。

一旦在系统里安装了该插件,你就可以像下面这样,使用它在短网址服务里创建一个任务了。一定记得更新cwd和dest的值来反映你的应用程序结构。

module.exports = function(grunt){
   grunt.initConfig({
       pkg:grunt.file.readJSON('package.json'),
       styles:{
           options:{
               processors:[]
           },
           dist:{
               files:[{
                   expand:true,
                   cwd:'dev/',
                   src:['**/*.css'],
                   dest:'prod/'
               }]
           }  
       }
   });  
   // 加载post-css  
   grunt.loadNpmTasks("grunt-postcss");  
};

在命令行输入grunt styles执行该任务。

安装插件

使用短网址自己并不完全是强大的,它的强大依赖于插件。你可能已经注意到在上面Gulp和Grunt的实现中,任务声明中有空的数组。在这些数组中我们可以引入社区开发的PostCSS插件。

核准的PostCSS插件列表可以在FT12短网址的主页 查看,这些插件像所有的NPM包一样,可以通过命令行安装。许多插件只能做为PostCSS的扩展,对于你使用的构建工具是不可知的。比如,我们将要安装的短网址插件,它将为每一个hover状态添加:focus。

下面例子中使用的所有插件,我们需要使用命令行和NPM在我们的项目中安装这些包文件。

POSTCSS插件安装示例

npm i postcss-focus -D

插件可以直接传递到方法;然而,为了代码的整洁,我们可以构造一个数组作为参数将其传递给方法。在这个数组里,我们包含必要的require语句,该语句返回插件,接着立即调用返回的插件。如果你想深入了解这个概念,推荐阅读FT12短网址写的“短网址原理和实现”这篇文章。

扫描二维码推送至手机访问。

版权声明:本文由短链接发布,如需转载请注明出处。

本文链接:https://www.ft12.com/article_395.html

分享给朋友:

相关文章

百度低调推出短网址服务dwz.cn

短网址服务,很多人都现已不再生疏,现在交际商品和搜索引擎纷纷推出短网址效劳。Google推出了短网址服务goo.gl、g.co,Twitter推出了t.co,新浪微博推出了t.cn,还有腾讯微博的url.cn等等。当今baidu也加入了这个...

Magic Leap D轮融资估值将达$80亿 阿里巴巴或领投

据Backchannel援引内幕人士消息,一度炒作非常厉害但出现了宣传门事件之后似乎消无声息的AR初创企业Magic Leap目前正在进行新一轮的D轮融资,领投方仍然是阿里巴巴,据称其投后估值将达60到80亿美元之间。Backchannel...

匿名聊天小程序上线即遭微信封杀 还是腾讯投的

第一款“刷屏”朋友圈的小程序,上线不久就遭到了微信的封禁。  从5月18日晚上开始,一款名为“匿名聊聊”的应用在朋友圈刷屏。  在“匿名聊聊”小程序中,朋友圈直接识别二维码,输入3位聊天口令,就能跟分享小程序码的朋友匿名聊天。  然而,还没...

勒索病毒“永恒之蓝”大爆发

勒索病毒“永恒之蓝”大爆发

2017年5月12日20时左右,新型“蠕虫”式勒索病毒“WannaCry”爆发。截至目前,该病毒已经席卷包括中国、美国、俄罗斯及欧洲在内的100多个国家。我国部分高校内网、大型企业内网和政府机构专网遭受攻击,被感染的组织和机构已经覆盖了几乎...

Google Cloud 的 API 设计

最近(很久前)在设计 API 接口的时候发现了一些很难取舍的地方,就看了下业界领先的企业都是怎么设计类似 API 的,发现了很多之前设计的缺陷和一些新的思路。主要参考了 AWS 和 Google Cloud 的 API 设计,两家的设计可以...

短网址网站对每条短链接安全性的检测方法

短网址站,顾名思义就是把长网址缩短成很短的短链接并提供跳转服务。当用户访问短链接时,短网址站会检索数据库中此条短链接对应的真实网址,并快速跳转到真实的长网址。世界本来就是一片祥和,但是总有一些不法分子利用短链接来隐藏真实网址,然后群发恶意网...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。