用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)


Posted in Javascript onDecember 05, 2018

自己学习使用了Angular JS 1一段时间,由于没有具体的项目进行尝试加上其它研究工作的影响,就搁置了一段时间。在与同事讨论技术选型时,才知道Angular JS 2的差别之大(孤陋了,莫见笑),所以决定弄弄Angular 2。WebStorm是进行JS和前端开发的不二之选的IDE工具,虽然目前版本已经更新了,但是由于Angular 2的成熟度还没那么高,所以用WebStorm进行Angular 2的工程创建,还是没有其他语言的方便。自己尝试用WebStorm搭建Angular 2的工程,虽然在网上看了一些仁兄的帖子,很有帮助,但是感觉关键的、核心的问题没有说清楚(也可能是由于用Node不是很久,知识浅薄),所以搭建过程特别是在Windows上也是磕磕绊绊,总是有些问题。相信其他人也会遇到同样的问题,所以将问题梳理总结如下。

一、前序

既然是使用Angular JS 2,那么先简单说下 1 和 2 的主要区别。这方面内容,网上很多,我就借用其他仁兄的一些资料,具体来源可以查看:参考资料

Angular 1与 Angular 2之间的一些差别

Angular2使用了javascript的超集‘Typescript',所以angular1和angular2从设定之初就是不一样的;

Angular1.x在设计之初主要是针对pc端的,对移动端支持较少(当然也有其他一些衍生框架如ionic),而Angular2是设计包含移动端的;

Angular 1的核心概念是scope,但是angular2中没有scope,angular2使用zone.js来记录监测变化;

Angular 1 中的控制器在angular2中不再使用,也可以说控制器在angular2中被‘Component'组件所替代:

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

二、环境准备

  • WebStorm 2016.3.3
  • Nodejs 7.4.0
  • angular-cli 0.31
  • Windows 10 RedStone

WebStorm安装很简单,破解不是本文重点,建议还是支持正版。

(1)Nodejs安装

这一步很简单,下载Windows版的Nodejs,进行按照提示安装即可,记得选择将nodejs增加到PATH一项,如果界面上没有,应该就是默认帮你搞定了,可以忽略我这句废话。

通过命令,验证是否安装成:

node -v
npm -v

如果正常显示版本号,即安装成功。

(2)Nodejs配置

Nodejs安装完成之后,默认会将node.exe的路径,添加到系统的环境变量中,如果没有请手动添加。除此之外还要进行其他的配置。

1、配置prefix和cache目录

示例目录地址为:C:\Program Files\nodejs

npm config set prefix “C:\Program Files\nodejs\node_global”
npm config set cache “C:\Program Files\nodejs\node_cache

2、配置环境变量

右击“计算机”—>”属性”—>”高级系统设置”—>”环境变量”

在”系统变量”中,设置 NODE_PATH

在系统变量里新建 NODE_PATH ,值为

C:\Program Files\nodejs\node_global\node_modules

这个值就是上一步中,通过 “npm config set prefix” 设置的值。可以,用下面命令查看

npm config get prefix

在”用户变量”中,修改path

修改用户变量中的path,添加C:\Program Files\nodejs\node_global\。

这个值就是上一步中,通过 “npm config set prefix” 设置的值。

3、配置sass_binary

angular cli 是要依赖node-sass的,默认情况下,不会像其它包一样直接下载,而是要下载后进行编译的。在Windows下,首先要通过git下载win32-x64-51_binding.node,但是不知道是被墙还是什么原因,下不下来,就会导致后面的编译出错,以及提示找不到python和Visual Studio的问题。如下:

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

首先要做的就是根据错误提示,手动下载相应的版本地址:binding.node

将下载的binding.node放到指定目录,例如:

C:\win32-x64-51_binding.node

配置路径:通过命令配置

npm config set sass_binary_site “https://npm.taobao.org/mirrors/node-sass/” //使用阿里的镜像

npm config set sass_binary_path “C:\win32-x64-51_binding.node”

当然以上prefix, cache,sass_binary_site, sass_binary_path等,也可以通过修改下面文件进行配置

C:\<username>\.npmrc

prefix=C:\Program Files\nodejs\node_global
cache=C:\Program Files\nodejs\node_cache
sass_binary_site=https://npm.taobao.org/mirrors/node-sass/
sass_binary_path=C:\win32-x64-51_binding.node

(3)安装工具包

1、全局安装阿里cnpm

npm install -g cnpm --registry=https://registry.npm.taobao.org

2、全局安装typescript

npm install -g typescript typings

3、全局安装angularjs-cli

npm install -g @angular/cli

新版已经不用angular-cli进行安装,而是使用@angular/cli,参见官网

三、创建工程

1、打开WebStorm新建一个Angualr CLI 工程

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

  • nodejs如果安装好,WebStorm会自己扫描到指
  • 定工程目录和名称
  • 指定angular-cli的目录

很多帖子只说指定angular-cli的目录,没有说清楚具体是哪个目录。但是最开始我在指定的时候,一直还提示“Please specify angular-cli package”。还以为是angualr-cli没有安装对。

通过尝试发现:

(a)具体的目录,就是angular-cli包中,bin目录的上一层目录

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

(b)如果目录选择完成后,还提示:“Please specify angualr-cli package”,就点击一下工程名称那一栏或其它地方。因为选择angular-cli目录,不会触发事件,所以错误提示一直在,点了其它地方,触发一下事件,提示就会消失,“Create”按钮就可以使用。

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

2、等待工程创建完成

以上工作完成,就是等待新建一个angular 2工程。这个过程有点慢,主要是IDE会根据package.json下载依赖的包到工程里面。

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

如果出现上图,就说明工程创建完成,工程结构如下

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

3、运行程序

选择package.json, 右键选择“Show npm Scripts”,或者用“Edit Configurations”,添加“npm”

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

点击“start” 启动 Web Server

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

在浏览器?入 http://localhost:4200 ,若出? app works! ,表示 Angular 2 已经正常启动。

用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
关于js日期转化为毫秒数“节省20%的效率和和节省9个字符“问题
Mar 01 Javascript
HTTP 304错误的详细讲解
Nov 13 Javascript
基于jQuery通过jQuery.form.js插件使用ajax提交form表单
Aug 17 Javascript
基于javascript实现样式清新图片轮播特效
Mar 30 Javascript
Vue项目中引入外部文件的方法(css、js、less)
Jul 24 Javascript
使用JavaScript实现表格编辑器(实例讲解)
Aug 02 Javascript
用最简单的方法判断JavaScript中this的指向(推荐)
Sep 04 Javascript
JavaScript实现新年倒计时效果
Nov 17 Javascript
快速了解Node中的Stream流是什么
Feb 13 Javascript
优雅地使用loading(推荐)
Apr 20 Javascript
vue 动态表单开发方法案例详解
Dec 02 Javascript
jQuery实现简单聊天室
Feb 08 jQuery
详解angularjs4部署文件过大解决过程
Dec 05 #Javascript
jQuery的ztree仿windows文件新建和拖拽功能的实现代码
Dec 05 #jQuery
关于RxJS Subject的学习笔记
Dec 05 #Javascript
node实现生成带参数的小程序二维码并保存到本地功能示例
Dec 05 #Javascript
详解如何在Angular优雅编写HTTP请求
Dec 05 #Javascript
JS+HTML5 canvas绘制验证码示例
Dec 05 #Javascript
详解关于Angular4 ng-zorro使用过程中遇到的问题
Dec 05 #Javascript
You might like
PHP 面向对象实现代码
2009/11/11 PHP
详解WordPress开发中get_header()获取头部函数的用法
2016/01/08 PHP
php生成word并下载代码实例
2019/03/15 PHP
为调试JavaScript添加输出窗口的代码
2010/02/07 Javascript
firefox下jquery iframe刷新页面提示会导致重复之前动作
2012/12/17 Javascript
jquery在IE、FF浏览器的差别详细探讨
2013/04/28 Javascript
jquery实现树形二级菜单实例代码
2013/11/20 Javascript
jquery实现的美女拼图游戏实例
2015/05/04 Javascript
JavaScript实现基于十进制的四舍五入实例
2015/07/17 Javascript
JS实现新浪微博效果带遮罩层的弹出框代码
2015/10/12 Javascript
基于Javascript实现弹出页面效果
2016/01/01 Javascript
获取IE浏览器Cookie信息的方法
2017/01/23 Javascript
详解nodeJS之路径PATH模块
2017/05/31 NodeJs
JavaScript数据结构与算法之队列原理与用法实例详解
2017/11/22 Javascript
JavaScript函数apply()和call()用法与异同分析
2018/08/10 Javascript
Javascript作用域和作用域链原理解析
2020/03/03 Javascript
从零学python系列之教你如何根据图片生成字符画
2014/05/23 Python
Python装饰器知识点补充
2018/05/28 Python
使用python中的in ,not in来检查元素是不是在列表中的方法
2018/07/06 Python
python traceback捕获并打印异常的方法
2018/08/31 Python
python获取中文字符串长度的方法
2018/11/14 Python
python适合人工智能的理由和优势
2019/06/28 Python
浅谈Python小波分析库Pywavelets的一点使用心得
2019/07/09 Python
使用python批量修改文件名的方法(视频合并时)
2020/03/24 Python
python3中关于excel追加写入格式被覆盖问题(实例代码)
2020/01/10 Python
python中tab键是什么意思
2020/06/18 Python
IE浏览器单独写CSS样式的几种方法
2014/10/14 HTML / CSS
倩碧英国官网:Clinique英国
2018/08/10 全球购物
MIKI HOUSE美国官方网上商店:日本领先的婴儿和儿童高级时装品牌
2020/06/21 全球购物
行政监察建议书
2014/05/19 职场文书
承诺书模板大全
2015/05/04 职场文书
2016应届毕业生实习心得体会
2015/10/09 职场文书
Python下opencv使用hough变换检测直线与圆
2021/06/18 Python
openstack中的rpc远程调用的方法
2021/07/09 Python
MySQL非空约束(not null)案例讲解
2021/08/23 MySQL
SQL Server一个字符串拆分多行显示或者多行数据合并成一个字符串
2022/05/25 SQL Server