JavaScript包管理器综述
JavaScript包管理器综述
作者:chszs,未经博主同意不得转载。经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs
对于JavaScript来说。包管理器并非一个新概念,npm和bower是JavaScript的两个最流行的包管理器工具,JavaScript的包管理器还有volo、ringojs、component。这些包管理器相比,npm和bower支持的JavaScript库和模块最多。
volo:http://www.volojs.org/ 。一个基于Node.js的工具,可用于高速创建项目、加入依赖库、自己主动化常见的任务。
ringojs:http://ringojs.org/ ,
Ringo是基于JVM的JavaScript平台。针对server端应用进行了优化。用于开发多线程的JavaScript程序。
Ringo峰值了大量内建的模块,遵循CommonJS标准。Ringo基于Mozilla的Rhino JavaScript引擎。而Rhino JavaScript引擎是JDK 6以上内嵌的脚本引擎。Ringo在Rhino的基础上进行了增强。主要是多线程编程这部分。
rp是RingoJS的包管理器,其目标是为本地RingoJS安装提供简易的包管理,以及在远程包注冊表中公布包。
Component:https://github.com/componentjs/component 。这个包管理器项目已经停止维护了。
Jam:http://jamjs.org/ 。一个JavaScript的包管理器,能够管理依赖、高速载入和模块化,与Bower类似,仅仅管理前端的JavaScript模块。
webpack:http://webpack.github.io/ ,一款开源的模块载入器兼打包工具,它能把各种资源比如JS(含JSX)、coffee、样式(含less/sass)、图片等都作为模块来使用和处理。
jspm:http://jspm.io/ ,是基于SystemJS的Javascript包管理器,是基于动态的ES6模块载入器之上构建的工具。
browserify:http://browserify.org/ ,让开发人员使用类似于Node.js的require()方式来组织浏览器端的JavaScript代码,通过预编译让前端JavaScript能够直接使用Node NPM安装的一些库。
npm主要处理兼容Node.js的JavaScript模块,而Bower聚焦于整个Web平台,能够提供包括模块、脚本、CSS样式表、HTML模板、图片Image、字体的包。
故npm主要用于Node.js开发。bower往往工作于client。
npm和bower使用了互不兼容的组织模式,能够在同一个项目中一起使用,它们使用了不同的元数据文件,npm是package.json。bower是bower.json,并且它们把包安装到不同的文件夹下。
通常使用npm管理server端的包,使用bower管理client的包。
与Java Maven不同。JavaScript的包管理器主要用于查找包、安装包、管理包的版本号。
npm除此之外还提供了简单的build相关和test相关的任务。
使用JavaScript包管理器
1)在安装bower或npm后。在项目根文件夹首先应运行
bower init
npm init
包管理器会询问一些项目设置相关的问题。
一一回答后包管理器就会为项目创建bower.json或package.json配置文档。
2)要搜索可用的包,运行
bower search <关键词>
npm search <关键词>
包管理器会从网络仓库中搜出一堆包列表显示。
3)要安装包,运行
bower install <包名>
npm install <包名>
要安装包的指定版本号。命令语法例如以下:
bower install <包名>#<包版本号>
npm install <包名>@<包版本号>
还能够把项目使用的每个包的版本号信息都保存到项目的元数据文件里。包管理器(包括第三方的包管理器)都能够使用元数据文件来监护client的维护、构建、測试和启动任务。
当然,最佳的方法还是把包的版本号信息保存到项目的元数据配置文件里。使用–save选项。命令语法例如以下:
bower install --save <包名>#<包版本号>
npm install --save <包名>@<包版本号>
JavaScript包管理器综述的更多相关文章
- JavaScript 包管理器 -Yarn
Fast, reliable, and secure dependency management. 官网地址 Github 特性 离线模式:如果您之前下载了软件包,则可以在没有任何互联网连接的情况下安 ...
- Node.js包管理器Yarn的入门介绍与安装
FAST, RELIABLE, AND SECURE DEPENDENCY MANAGEMENT. 就在昨天, Facebook 发布了新的 node.js 包管理器 Yarn 用以替代 npm .咱 ...
- 你需要知道的包管理器(Package Manager)
最近我花了一点时间关注了在不同系统之中所用到的包管理器(Package Manager) .最开始的时候,我是在使用Linux操作系统时,对这种工具以及它背后的想法深深迷恋住了:这真是自由的软件世界. ...
- 【转】包管理器Bower详细讲解
包管理器Bower 今天自己用Angular写东西的时候,下载了Angular-seed项目,发现需要用到bower,之前也使用过,没有仔细了解,今天趁机了解到一些. bower的官网地址: ...
- Bower => 前端开发也有包管理器
摘要: 一直以来npm,pip等各种包管理器好像都和前端开发没什么太大关系,当然因为nodejs的原因可能感觉npm会亲切一些,不过终归不是针对客户端的包管理工作,所以Bower的出现确实让人眼前一亮 ...
- 包管理器Bower使用手冊之中的一个
包管理器Bower使用手冊之中的一个 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs 一.Bower介绍 Bower是一个适合Web应用的包管理器,它擅长 ...
- 包管理器Bower使用手册之一
包管理器Bower使用手册之一 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs 一.Bower介绍 Bower是一个适合Web应用的包管理器,它擅长前端的 ...
- NET Core 静态文件及JS包管理器(npm, Bower)的使用
NET Core 静态文件及JS包管理器(npm, Bower)的使用 文章目录 在 ASP.NET Core 中添加静态文件 使用npm管理JavaScript包 使用Bower管理JavaScri ...
- Node.js包管理器:
Node.js包管理器: 当我们要把某个包作为工程运行的一部分时,通过本地模式获取,如果要在命令行下使用,则使用全局模式安装 使用全局模式安装的包并不能直接在JavaScript文件中用require ...
随机推荐
- hdoj--1010<dfs+奇偶剪枝>
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1010 题目描述:在n*m的矩阵中,有一起点和终点,中间有墙,给出起点终点和墙,并给出步数,在该步数情况 ...
- BZOJ 4819 [Sdoi2017]新生舞会 ——费用流 01分数规划
比值最大 分数规划 二分答案之后用费用流进行验证. 据说标称强行乘以1e7换成了整数的二分. 不过貌似实数二分也可以过. #include <map> #include <cmath ...
- 将Linux下python默认版本切换成替代版本
本文链接自http://www.myhack58.com/Article/48/66/2016/71806.htm 当你安装 Debian Linux 时,安装过程有可能同时为你提供多个可用的 Pyt ...
- [BZOJ4260] Codechef REBXOR (01字典树,异或前缀和)
Description Input 输入数据的第一行包含一个整数N,表示数组中的元素个数. 第二行包含N个整数A1,A2,-,AN. Output 输出一行包含给定表达式可能的最大值. Sample ...
- iOS-多线程(3)
多线程之GCD(grand central dispatch)中心调度 为了简化多线程的操作,iOS为我们提供了GCD来实现编程. 使用GCD只要遵守两个步骤即可: 创建对列(串行队列,并行队列) 将 ...
- Android ARM指令学习
在逆向分析Android APK的时候,往往需要分析它的.so文件.这个.so文件就是Linux的动态链接库,只不过是在ARM-cpu下编译的.所以学习Android下的ARM指令很重要.目前,市面上 ...
- C++基类与派生类的转换
具体表现在以下几个方面: 派生类对象可以向基类对象赋值. 可以用子类(即公用派生类)对象对其基类对象赋值.如 A a1; //定义基类A对象a1 B b1; //定义类A的公用派生类B的对 ...
- Best Coder Lotus and Characters
Lotus and Characters 问题描述 Lotus有nn种字母,给出每种字母的价值以及每种字母的个数限制,她想构造一个任意长度的串. 定义串的价值为:第1位字母的价值*1+第2位字母的 ...
- 【Visual Studio】VS2013的Release模式下进行调试(转)
原文转自 http://blog.csdn.net/haizimin/article/details/50262901 在有的情况下,我们可能不能直接利用Debug模式进行程序调试,那么如何在Rele ...
- Android系统默认输入法的修改为搜狗输入法
1. frameworks\base\packages\SettingsProvider\res\values\defaults.xml 文件中修改默认输入法为搜狗输入法 <stringnam ...