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

短网址服务的便利性介绍

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

引言

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

短网址就是最近才出现的这么一个工具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

分享给朋友:

相关文章

发力跨境业务 亚马逊在华力图“收复失地”

尽管没有发布清晰的扩张计划,但亚马逊我国已开端广纳人才,为新一轮商场包围战做准备。据彭博社日前报导,亚马逊在我国招聘数百名职工来填充网络软件工程师、Alexa设计师等岗位。但在近期发布的招聘岗位中,触及跨境事务的职位成为亚马逊的主要招聘方向...

成为人生赢家的一条捷径

成为人生赢家的一条捷径

作为一个合格的上班族,一般周一就已经在期盼着周六周日的到来。然而吃吃喝喝买买买之后,总会有一个烦恼。那就是——账单!一不小心花太多,下周又要吃土。更烦恼的是,身边的有很多朋友,周末一样过得很潇洒,但人家该买房买房,该出国出国,完全是一副“人...

大妈死于郎咸平,IT男死于翟欣欣,企业主死于贾跃亭,金融男死于比特币……

大妈死于郎咸平,IT男死于翟欣欣,企业主死于贾跃亭,金融男死于比特币……作者:FT12短网址近日,知乎上有一个帖子很火,说如果薛之谦、翟欣欣、马蓉、贾跃亭、邓文迪和郎咸平凑在一起,谁能“套”走谁的钱?玩法是这样的:如果给薛之谦、翟欣欣、马蓉...

FT12短网址:给你的女朋友解释为什么随机播放歌曲并不随机

FT12短网址:给你的女朋友解释为什么随机播放歌曲并不随机

FT12短网址的小编在周末的时候开车带着女朋友出去玩。小编车里面随机播放着五月天的歌曲。当小编正沉浸在『得儿飘,得儿飘,得儿意的飘』中,幻想着自己是秋名山车神,突然,旁边的豆腐,哦不,女朋友说话了。诶,你车上的歌曲是随机播放的吗?和短网址的...

特斯拉电动半挂卡车在加州曝光,一次计划内的“偷跑”?

特斯拉电动半挂卡车在加州曝光,一次计划内的“偷跑”?

[ FT12短网址 ] 根据规划,特斯拉的首款电动半挂卡车将于10月26日正式发布。但在10月4日,一位Reddit用户在其社交网站页面上传了一张包含疑似特斯拉半挂卡车的照片,他将该图描述为“加州一个用于特斯拉汽车开放测试的场地”...

你成功地报复过谁?

你成功地报复过谁?

我报复过我的父亲,非常精心的报复,屡次去尝试“复仇”式的报复,可坦白说,报复过后的感觉体验非常不好,空虚、无助、无力,没有丝毫成就感,看似是报复一个人,其实是伤害一群人,跟自己。少年时依靠母亲生活,父亲带给这个家的,全是屈辱。如果他只是那种...

发表评论

访客

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