[front]有效开展一个前端项目
今天的前端如果没有用到 npm,效率是比较低的;所以要从使用的工具来讲。
1. 一切都依赖于 nodejs:
下载一个 linux 的源码包就可以开始安装了。
$ wget https://nodejs.org/dist/v4.4.7/node-v4.4.7.tar.gz
$ ./configure --prefix=/usr/local/nodejs
$ make && sudo make install
装好后,npm 已经在/usr/local/nodejs/bin/npm。
如果之前有安装过 nodejs 的情况,最好确认下当前使用的是否是刚安装的命令:
$ which node
$ which npm
把不需要的旧版本删除即可。
2. 用 npm init 建一个项目依赖包的说明文件 package.json:
{
"name": "front",
"description": "my application",
"version": "0.0.1",
"author": {
"name": "farwish"
},
"main": [
"index.js"
],
"license":"MIT",
"repository":{},
"dependencies": {
}
}
3. 任务流命令 gulp:
先把 nodejs 的命令加到环境变量里,可以直接加 /usr/local 到 PATH 中。
( PATH=$PATH:$HOME/.local/bin:$HOME/bin:/usr/local )
$ source ~/.bash_profile
$ npm install -g gulp # 全局安装,gulp 命令会装到 /usr/local/nodejs/bin/
$ npm install gulp --save # 安装到当前项目的 node_modules/,并写入package.json的dependencies
如果出现权限错误,一般是 /usr/local/nodejs/lib/node_modules 没有写权限,全局安装用 root 用户;
本地 Local gulp 用普通用户安装,把 npm 建立在项目中的 node_modules/ 所属改成当前用户和用户组。
4. 一个实用库 browserSync:
browserSync 能检测文件变动并自动刷新浏览器,不依赖浏览器插件。
$ npm install browser-sync --save
(browser-sync start --server --files "src/*.html" # 用于静态文件,监测src目录的html文件)
(browser-sync start --proxy "localhost:8080" --file "css/*.css" # 动态站点使用代理模式)
5. 建一个任务流文件 gulpfile.js:
在 gulpfile 中使用 browserSync 库。
var gulp = require('gulp');
var browserSync = require('browser-sync');
var path = {
src:"src/*.html"
};
// 名叫 browser-sync 的任务
gulp.task('browser-sync', function() {
browserSync({
files: "**",
server: {
baseDir: "./"
}
});
});
// gulp 自动执行 default 任务
gulp.task('default', ['browser-sync']);
$ gulp # 运行gulp,然后编辑并保存监听的文件就能看到效果
6. 第一开发框架 angularjs:
小巧的 css 库有 pure,功能型的有 uikit,至于 bootstrap 已经满大街,随便选。
js 框架首选 angularjs,不过库的尺寸都不小。
angular 也是一个能快速搭建原型的工具,通过 ui-router 很容易组织页面间关系。
完全抛弃 dom 操作和 load 操作的感觉,和 jquery 时代有巨大差别。
angular 的难点在于概念,各种 $provider 令人迷惑,实际上框架我们知道怎么用就行,不用盯住具体哪个是什么概念,能用起来,后面省事省力。
Link: http://www.cnblogs.com/farwish/p/5656959.html
[front]有效开展一个前端项目的更多相关文章
- [FE] 有效开展一个前端项目1
今天的前端如果没有用到 npm,效率是比较低的:所以要从使用的工具来讲. 1. 一切都依赖于 nodejs: 下载一个 linux 的源码包就可以开始安装了. $ wget https://nodej ...
- 使用gulp来构建一个前端项目
什么是gulp? gulp是一个前端项目构建工具,是自动化项目的构建利器,它不仅能对网站资源进行优化,而且在开发过程中很多重复的任务能够使用正确的工具自动完成.你可以使用gulp及其插件对你的项目代码 ...
- 从一个前端项目实践 Git flow 的流程与参考
Git flow 出自 A successful Git branching model,这里使用了一个前端项目配合本文稿实施了 git flow 并记录流程作出示例和参考,对 hotfix 与持续部 ...
- [FE] 有效开展一个前端项目2 (vuejs-templates/webpack)
1.安装 nodejs.npm $ curl -sL https://deb.nodesource.com/setup_10.x | sudo -E bash - $ sudo apt-get i ...
- vsCode怎么为一个前端项目配置ts的运行环境
vsCode为一个前端项目配置ts的运行环境,ts文件保存的时候自动编译成js文件: 假设此前端项目名称为Web:文件结构如图 1. 在根目录中新建一个“.vscode”文件夹,里面建一个“tasks ...
- webpack(构建一个前端项目)详解--升级
升级一个正式的项目结构 分离webpack.config.js文件: 新建一个webpack.config.base.js任何环境依赖的wbpack //public webpack const pa ...
- webpack(零工程构建一个前端项目)详解
工作流程记录: 1.初始化项目:npm init -y 2.安装webpack,vue,vue-loader npm install webpack vue vue-loader 3.按装之后根据警告 ...
- 前端项目中gulp的使用
在公司项目开发中,有一个前端项目,我们使用gulp来生成目标文件(css,js,html文件) 进入到这个项目目录中 C:\My Project\FrontEnd\TestBuilder 然后依次运 ...
- [Vue 牛刀小试]:第十六章 - 针对传统后端开发人员的前端项目框架搭建
一.前言 在之前学习 Vue 基础知识点的文章中,我们还是采用传统的方式,通过在 html 页面上引用 vue.js 这个文件,从而将 Vue 引入到我们的项目开发中.伴随着 Node.js 的出现, ...
随机推荐
- mysql卸载(转)
按以下步骤卸载mysql server 主要步骤: 1. 停止服务MySQL 2. 卸载mysql相关的程序 3. 删除注册表(运行->regedit),machine->system-& ...
- Druid Monitor监控JavaSE,杀cmd端口进程
1.需要在启动命令添加相关jvm参数 -Dcom.sun.management.jmxremote -Djava.rmi.server.hostname -Dcom.sun.management.jm ...
- jQuery iframe之间相互调用
,子iframe内调用父类函数方法: window.parent.func(); ,子Iframe中获取父界面的元素: $("#xx", window.parent.documen ...
- Java:多态(向上转型)
先来看一段代码: class BaseClass{ public int book = 6; public void base(){ System. ...
- innodb buffer pool小解
INNODB维护了一个缓存数据和索引信息到内存的存储区叫做buffer pool,他会将最近访问的数据缓存到缓冲区.通过配置各个buffer pool的参数,我们可以显著提高MySQL的性能. INN ...
- 怎么评价Facebook的Relay框架?Meteor.js 是什么?
http://www.zhihu.com/question/34531232?rf=34500201 Meteor.js 是什么? 作者:陈天链接:http://www.zhihu.com/quest ...
- react-native 好多坑,记录下。
1 classpath 'com.android.tools.build:gradle:1.2.3' 2.adb reverse tcp:8081 tcp:8081 3.react-native ru ...
- Redis从基础命令到实战之有序集合类型(SortedSet)
有序集合类型是Redis五种数据类型中最高级的.也是最复杂的类型.有序集合具有集合类型的特性,在其基础上给每个元素关联了一个分值,或称为权重,操作时既可以在添加元素时指定分值,也可以单独修改集合中某一 ...
- php面向对象之final的应用
final从英文字面上很容易理解,翻译成中文就是“最终的”之意.在php面向对象编程中,final的应用主要有两个作用: 1.使用final修饰的类,该不能被继承 01 <?php 02 ...
- C, C#, AS3的变量
高级语言中变量分值类型和引用类型, C中则分栈和堆, 在作为函数参数传递时,值类型复制,引用类型传递引用,不复制: 高级语言中一些基本类型默认是值类型, 其他基本都是引用类型. C语言中栈和堆变量可以 ...