URL Segment: 'main' 这个问题的处理很简单,是路由的路径写错了, import { NgModule } from '@angular/core'; import { Routes,...imports: [RouterModule.forRoot(routes)], exports: [RouterModule], }) export class MyRoutingModule { } 我的情况是在父组件中调用子路由的时候...,出现这个问题的,大家只需要更改一个地方, {path:'',redirectTo:'main',pathMatch:'full'} 把main 前的斜杠去了就好了,我想问题的原因是因为调用的是子路由,...反正问题是解决了解决了
指令是对HTML进行扩展的基本手段 三种指令(注:组件也是一种指令): 组件:一种带有模板的指令;使用component来装饰组件类 属性指令:改变元素的外观或行为,如NgClass,NgStyle;
在console中不是打印出具体到哪个组件,而是打印出core.es5.js,这样对我的调试困难就加大了很多 如果不小心按到了chrome里的哪个调试开关的时候,自己也不清楚哪里解决好,直接重置就可以。
angular2最后想打包放到服务器,需要在文件目录运行 ng build 命令,运行完会生成一个 dist 目录,将这个目录放到服务器上就可以了。...但是这一过程出了点问题,打开index.html一片空白,控制台报错 ? image.png 打包生成的文件路径错误找不到文件。原因可能是我的文件不是直接放在服务器根目录下。...后来发现可以直接在ng build后面跟指定的路径,比如说 ng build --base-href /test/dist/ 或者 缩写ng build --bh /test/dist/ 访问的地址是...http://localhost/test/dist/ 问题就解决了 要是图片引用还有问题可以把引用路径改为相对路径。...网上有的方法说吧package.json的build加上上述参数,然后ng run build也可以,我这边不行不知道为什么。大家可以试一下。
constructor() { this.name = 'World'; } } selector (选择器): 我们用它来告诉Angular创建和插入这个组件实例的元素属性...templateUrl(模版地址): HTML的一种形式,它告诉Angular如何呈现这个组件。...template (模板): HTML的一种形式,它告诉Angular如何呈现这个组件。...styleUrls(模版样式地址): css样式,在组件模版中引用的css样式。 ---- sivona
http://www.jianshu.com/p/8943ff86349a 之前这篇是说了路径的问题 这次是说准备部署时的打包 首先还是基于这个 ng build --base-href /test.../dist/ 但这样打包出来的代码非常大,所以需要生产环境的打包 ng build --prod --base-href /test/dist/ --save 或者 ng build --prod...的问题开发时不会报错,但生产环境下打包就会报错。...还有类似item.a.b这种如果a是后来才创建的,也会报错,改成item.a['b']这种方式就可以解决。这些报错我的解决方式就是一个个对着去改,不知道还有没有什么更好的方法。...还有如果想用cdn的方式引用外部代码,可以直接在index.html的头部写 <script type="text/javascript" src="https://cdn.bootcss.com/
angular2路由页面之间的跳转, 只需要在需要跳转的ts文件中引入 import {Router} from '@angular/router'; 然后在 constructor(public router...:Router) { } 定义好router,这样就可以使用Router中的属性了 doJump(){ this.router.navigate(['/index'])//跳转到新的路由页面 }
"时间的教训" - 何为时间的教训呢?...所谓时间的教训,那就是,不论这个东西难或者易,本来在一定的时间内,甚至小于这个一定的时间就可以完成的,而你偏偏用了2倍甚至三倍的时间来完成,更有甚者根本完不成的东西,但是最后解决了之后,你却发现,只是因为你少想了一点...教训 其实这个地方,我可以有两种方式可以很快的定位到问题的所在。 第一种方式就是,我去往上看,具体哪里使用的sino-list这个组件,去找到根本的使用它的地方,这个错误也是这样解决的。...2.第二种方式就是,使用Angury这个调试,去查看其中的component树,这样就能很快的查找问题。 ? 展示图 ?...依赖DI系统的service的依赖注入方式 就是通过模块的封装,将BaseDataService注入到了angular的DI系统中,这样在模块中的所有组件,都可以通难过angular的DI注入的方式获取到
expression是一个数字: digitInfo是string具有以下格式的: {minIntegerDigits}....{minFractionDigits}-{maxFractionDigits} minIntegerDigits是要使用的最小数字的整数数字。...默认为1 minFractionDigits是分数后的最小位数。 默认为0 maxFractionDigits是分数后的最大位数。...value: string) { this.value = value; } } 4.日期格式转换 {{ today | date[:format] }} today是一个日期对象或数字(自UTC时代以来的毫秒...)或ISO字符串 [:format] 指明要包括的日期/时间组件。
自从接触angular2以来,组长就提到了3个对于我来说是新东西的东西: angular2 typescript es6 ionic 其实对于这3个东西来说,我根本搞不清楚他们之间的关系,突然之间意识到...--阮一峰 ECMAScript和JavaScript的关系 由于JavaScript的创造者Netscae公司的版权问题吧,ECMAScript不能叫Javascript。...angular2 AngularJS是一款优秀的前端JS框架**。 AngularJS2是基于typescript来开发的。...至于需不需要使用,在于你所需要的场景。比如在Angular2中,用TypeScript明显好于ES6。...错误更正 由于之前错误的把decorator解释为注解,那么下面就Angular2 中的Annotation和Decorator之间做一个简单的对比性学习。
最近在用Angular2,需要有一个上传文件的功能,但是又不想用库,所以直接用原生的input file 标签。... 然后想获取上传的内容,于是先想了个愚蠢的方法,先通过id获取到这个input标签,然后再获取其中上传的内容 const uploadsFile...于是在es6里找了下有files属性的类型,是HTMLInputElement类型。于是就强制它转换成这个类型。...HTMLInputElement>document.getElementById(name); const file = uploadsFile.files[0]; 后面发现这种方式好像有点愚蠢,于是换了一个方法,用angular2...里的$event来获取输入内容,里面也包括选择上传的文件。
本文选自《迈向Angular 2》,让我们看看Angular2解决了哪些在1.x版本中困扰我们的问题。...在《迈向Angular2》第4 章,将会学习如何用Angular 2中的组件和指令来取代AngularJS1.x 中控制器的功能。...新版本的DI 更灵活、功能更丰富,也消除了AngularJS 1.x 中的一些误区,例如API 不统一的问题。...当需要维护一个用JavaScript 编写的庞大的代码库时,我们可能要换一个角度来看数据流的问题。...《迈向Angular2》第4 章,会学习到新的脏值检测机制以及它们的配置方法。
component produce 可以直接创建指令并更新app.module.ts; ng g service shared/login ; 可以直接创建服务,保存到shared文件下; 因为刚接触angular2
服务器: 腾讯云主机(Centos 7.1) 项目:aspnetcore+angular2 开源项目模版 该项目使用webpack 打包Angular2, 内网涉及到npm请使用tnpm 环境安装 1....安装dotnetcore 根据官方指导进行安装; 官网给出的安装引导是安装dotnet core 1.1 ,但是我们项目使用的dotnetcore 1.0.1 所以必须再安装1.0.1 (备注dotnet...systemctl start nginx 使用命令行测试 curl http://127.0.0.1 能访问到html内容则正常 项目构建 1.构建项目 在windows环境 构建 指引 参考 npm如果访问问题可以使用...yo npm install -g generator-aspnetcore-angular2 2.创建项目 选择高级模版 取消npm 安装 使用 tnpm 3.编译项目 编译dotnet ,编译angular2...dotnet 程序集restore,webpack 打包Angular2 ,本地运行项目 有兴趣的同学可以多了解快命令具体做了啥 4.本地访问 http://localhost:3000/ 部署项目
ERROR in Cannot use 'in' operator to search for 'providers' in null 出现这个问题的原因是,在使用懒加载的时候,没有指定module,...没有找到相关的提供信息。.../home/home/home.module'},] 以上是修改之前报错的代码: 以下是修改之后不报错的代码,只需要给其指定一module: const routes: Routes = [ {path
1.前言 前几天刚下定决心把毕业设计改造下,因为毕业设计算是我学习的基石,学习到的东西都尽可能的在这个平台上施展,锻炼自己.改造为前后端分离,前端使用angular2,后端只提供接口.便于以后的维护.那么就要学习...,给你带来的则是更多的实战经验. 2.angular2简介 angular2是类似全家桶组合的框架,所需要的东西几乎都包办了,所以开发起来很迅速....支持 WebStorm对angular2的强大支持....,self并不受angular管理,导致刷新的变量是self中的isBackColor. 3.2http参数传递 按照下面代码传参数应该是没有问题的,但是我遇到了url被编码问题,例如输入`1111@qq.com...angular2的路由匹配规则是从根路由也就是forRoot()的这个开始.在该处匹配寻找规则.
Angular2 和 AngularJS 1.x 相比, 可以说是全新的框架, 除了名字有延续性之外, 能延续的真的不多。...: mkdir learning-angular cd learning-angular npm init 编辑生成的 package.json 文件, 添加 angular2 的 npm 包及其依赖项...npm install 使用 es5 开发 Angular2 应用 Angular2 是个客户端框架, 在浏览器中运行, 因此使用 Javascript (es5) 来做开发也是完全可行的。...首先在 HTML 页面中添加 Angular2 的 UMD 版本 js 文件的引用, 代码如下: Angular2 应用 虽然完全能够使用 Javascript es5 来开发, 但是这并不是官方推荐的做法, 官方推荐的是 TypeScript , 默认的教程也都是使用
Why Angular2 Angular1.x显然非常成功,那么,为什么要剧烈地转向Angular2? 性能的限制 AngularJS当初是提供给设计人员用来快速构建HTML表单的一个内部工具。...初识Angular2 写一个Angular2的Hello World应用相当简单,分三步走: 1....引入Angular2预定义类型 import {Component,View,bootstrap} from "angular2/angular2"; import是ES6的关键字,用来从模块中引入类型定义...,可能隐约会感受到Angular2中bootstrap的一些 变化 - 我指的并非代码形式上的变化。...而在Angular2中,bootstrap是围绕组件开始的,你定义一个组件,然后启动它。如果没有一个组件, 你甚至都没有办法使用Angular2!
那么,本文将会对Angular2和Angular4进行深度对比,以便帮助大家更好的了解这两个版本。 Angular2 Angular2是在2015年底发布的。...接下来一起了解Angular2这个版本发布的原因以及如何将其添加到Web开发中。 ...Angular2 的特性和性能 AtScript是ES6的超集,用于帮助Angular2的开发。...依赖注入在模块化开发和元素隔离方面非常有帮助,但它的实现一直受到Angular 1.x的困扰。Angular2解决了这个问题,另外还添加了一些缺少的功能,如子注入以及生命周期/范围控制。...动态载入: 这是之前的Angular版本均不具备的功能,Angular2包含了这个功能,即使在开发人员忙碌时,也能够添加新的指令或控件。 模板: 在Angular2中,模板编译过程是异步的。
那么这里就有两个很重要的问题了:当数据变化时,这些框架/库是如何感知到的?当我们连续更新数据时,这些框架/库如何避免连续更新DOM,而是进行批量更新?...带着这两个问题,我将简要分析一下React、Angular1、Angular2及Vue的实现机制。...新手常碰到的一个问题就是为啥下面的代码不起作用。...Angular2 当数据变化时,Angular2从根节点往下遍历进行更新,默认Angular2深度遍历数据,进行新老数据的比较来决定是否更新UI,这点和Angular1的脏值检测有点像,但是Angular2...Angular1是通过封装自动调用$apply,但是存在手动调用的场景,为了解决这个问题,Angular2没有采用1的实现机制,转而使用了Zone.js。