Angular 核心概念2
自定义指令
- 指令增强了 HTML,提供额外的功能
- 内置的指令基本上已经可以满足我们的绝大多数需要了
- 少数情况下我们有一些特殊的需要,可以通过自定义指令的方式实现
普通指令
- 语法
<div hello-world></div>
<hello-world></hello-world>
angular.module('myModule', [])
.controller('HelloController', ['$scope', function($scope) {
$scope.customer = {
name: '张伟',
address: '五棵松下一站'
};
}])
.directive('helloWorld', ['$log', function($log) {
// 此处为指令工厂 工厂应该返回指令对象
return {
template: 'Name: {{customer.name}} Address: {{customer.address}}'
};
}])
- 请参照资料-备课代码-01-custom-directive.html理解
内容转置
- 把页面指令中的内容转置到指令中template中有ng-transclude指令的innerhtml中
- transclude属性:bool
- replace属性:bool 是否替换指令的dom元素
- 请参照资料-备课代码-02-custom-directive.html理解
模板抽取
- template属性是不支持html代码段换行的,所以把大量的html写在里面结构会很不清晰,我们可以借助templateUrl属性抽离模板页面
- templateUrl属性就是以异步请求的方式去请求模板
- 请参照资料-备课代码-02-custom-directive.html理解
指令的独立作用域
- 每个模块中的$scope都有自己的独立作用域
- 请参照资料-备课代码-04-scope.html理解
- scope属性:object,可以实现指令的独立作用域
- 请参照资料-备课代码-03-custom-directive.html理解
作用域的属性传递
- 语法
scope: {
title: '@',
type: '@'
},
<div class="row">
<div class="col-md-4">
<bs-panel type="default" title="panel1">
lsdjfklsdjfklsajdflsdaj
</bs-panel>
</div>
<div class="col-md-4">
<bs-panel type="default" title="panel2">
lsdjfklsdjfklsajdflsdaj
</bs-panel>
</div>
</div>
- @ 指的是当前属性在执行时会去取指令作用到的DOM元素的title
- 请参照资料-备课代码-03-custom-directive.html理解
自定义指令的类型
restrict属性可以定义指令的使用类型
- E:Element(元素)
- A:Attribute(属性)
- C:Class(类名)
- M:Comment(注释)
注意:在定义指令应该使用驼峰命名法,使用指令时应该使用的是全小写字母中划线分割的方式,注释的方式没有办法使用转置等功能
- 请参照资料-备课代码-03-custom-directive1.html理解
指令中的dom操作
- link属性是指令中可以操作dom元素的地方(css,属性,innerHtml)
- 请参照资料-备课代码-05-link-directive.html理解
- 语法
link: function($scope, element, attributes) {
// Scope是指令的scope,element是指令作用的dom元素,attributes是属性
// 我们经常说的dom操作指的是css,属性,innerhtml这些操作
element.on('mouseenter', function() {
element.css('backgroundColor', 'red');
}).on('mouseleave', () => {
element.css('backgroundColor', 'transparent');
});
}
过滤器
- 过滤器的主要用途就是一个格式化/筛选数据的小工具
- 一般用于服务端存储的数据转换为用户界面可以理解的数据
- 请参照资料-备课代码-06-filter.html理解
内置过滤器
- 语法
- 不同的过滤器语法不同
// 1: 需要过滤的数据,2: 过滤器的类型,3: 之后都是参数
{{ currency_expression | currency : symbol : fractionSize}}
- 也可以引入语言包,然后直接给过滤器类型即可
- 过滤器既可以在html中使用也可以在js中使用
常用的内置过滤器
currency
- 定义本位币类型
date
- 定义日期结构
json
- 输出有格式的对象,配合pre标签用于调试
lowercase
- 把大写字母变为小写字母
uppercase
- 把小写字母变为大写字母
number
- 定义小数点
limitTo
- 截取字符串操作
filter
- 模糊匹配对象中所有属性的值,和展示没有关系
- 如果传入一个对象的话,会根据特定的属性检索
- 请参照资料-备课代码-07-filter2.html理解
orderBy
- 按照指定的对象属性排序
- 请参照资料-备课代码-08-filter3.html理解
自定义过滤器
- 根据自己的需求定义需要的过滤器
- 请参照资料-备课代码-09-filter4.html理解
服务
内置服务
$http
- 请求连接服务
自定义服务
factory
service
provider
路由
控制页面跳转的第三方插件
ng-route
ng-route使用步骤
- npm install angular-route -save
- 引入这个包
- 在自己的模块中添加 ngRoute模块依赖
- 路由配置(配置路由规则)
- 规则指的就是 什么样的请求 找什么控制器
- [{url:'/sdf',controller:'MainController'}]
- 编写对应的控制器和视图
主要方法
- when():配置路径和参数;
- otherwise:配置其他的路径跳转,可以想成default。
- controller:对应路径的控制器函数,或者名称
- template:对应路径的页面模板,会出现在ng-view处,比如"
xxxx
"
- templateUrl:对应模板的路径,比如"src/xxx.html"
- redirectTo:重定向地址
ui-router
官网地址
ui-router使用步骤
- 安装或者下载ui-router的包
- 引入这个包
- 在自己的模块中添加 ui-view模块依赖
- 路由配置(配置路由规则)
- 规则指的就是 什么样的请求 找什么控制器
- [{url:'/sdf',controller:'MainController'}]
- 编写对应的控制器和视图
ng-route和ui-router的区别
- ng-route在一个页面中只能有一个坑
- ui-router在页面中可以有多个坑
- ui-router封装了ng-route
扩展
browser-sync
- 安装
npm install browser-sync -g - browser-sync start --server --files=".,*.html"
作用
- 多浏览器同时浏览
- 代码热更新
其他
- 官网 https://www.browsersync.io/docs/command-line
- api
- 和gulp集成
- 3001的端口地址是管理平台
wappalyzer
Angular 核心概念2的更多相关文章
- Angular核心概念之五---过滤器
Filter:过滤器,用于在view中呈现数据时显示为另一种格式:过滤器的本质是一个函数,接收原始数据转换为新的格式进行输出: function(oldVal){ ... return newVal ...
- Angular核心概念
一.集成开发环境@angular/cli IE8之后才有debugger工具 2009,nodejs发布,前端Big Bang 1.1 基于NodeJS的工具链 打包工具 grunt 对js代码做合并 ...
- Angular 核心概念
module(模块) 作用 通过模块对页面进行业务上的划分,根据不同的功能划分不同的模块. 将重复使用的指令或者过滤器之类的代码做成模块,方便复用 注意必须指定第二个参数,否则变成找到已经定义的模块 ...
- 2 Angular 2 的核心概念
一.组件(Components): 组件是构成 Angular 应用的基础和核心,它是一个模板的控制类,用于处理应用和逻辑页面的视图部分.组件知道如何渲染自己及配置依赖注入,并通过一些由属性和方法组成 ...
- Angularjs -- 核心概念
angularjs旨在减轻使用AJAX开发应用程序的复杂度,使得程序的创建.測试.扩展和维护变得easy.以下是angularjs中的一些核心概念. 1. client模板 多页面的应用通 ...
- 第214天:Angular 基础概念
一.Angular 简介 1. 什么是 AngularJS - 一款非常优秀的前端高级 JS 框架 - 最早由 Misko Hevery 等人创建 - 2009 年被 Google 公式收购,用于其多 ...
- 领域驱动设计(DDD)部分核心概念的个人理解
领域驱动设计(DDD)是一种基于模型驱动的软件设计方式.它以领域为核心,分析领域中的问题,通过建立一个领域模型来有效的解决领域中的核心的复杂问题.Eric Ivans为领域驱动设计提出了大量的最佳实践 ...
- Javascript本质第一篇:核心概念
很多人在使用Javascript之前都至少使用过C++.C#或Java,面向对象的编程思想已经根深蒂固,恰好Javascript在语法上借鉴了Java,虽然方便了Javascript的入门,但要深入理 ...
- [程序设计语言]-[核心概念]-02:名字、作用域和约束(Bindings)
本系列导航 本系列其他文章目录请戳这里. 1.名字.约束时间(Binding Time) 在本篇博文开始前先介绍两个约定:第一个是“对象”,除非在介绍面向对象语言时,本系列中出现的对象均是指任何可以有 ...
随机推荐
- Ciel and Robot
C. Ciel and Robot time limit per test 1 second memory limit per test 256 megabytes input standard in ...
- 用Python开始机器学习(7:逻辑回归分类) --好!!
from : http://blog.csdn.net/lsldd/article/details/41551797 在本系列文章中提到过用Python开始机器学习(3:数据拟合与广义线性回归)中提到 ...
- 理解 JS 回调函数中的 this
任何变量或对象都有其赖以生存的上下文.如果简单地将对象理解为一段代码,那么对象处在不同的上下文,这段代码也会执行出不同的结果. 例如,我们定义一个函数 getUrl 和一个对象 pseudoWindo ...
- (转)Netfilter分析
看到一篇讲Netfilter框架的,如果有一点基础了的话对于捋清整个框架很好帮助,转下来细细阅读. 转自http://aichundi.blog.163.com/blog/static/7013846 ...
- Rendering Path
Rendering Path:渲染路径 设置:1.Player Setting,2.Camera(会覆盖PlayerSetting中的设置) 选择:根据渲染内容和目标平台来选择合适的Rendering ...
- Hibernate基础映射
在说Hibernate映射前,我们先来了解下对象关系映射 ORM.ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现.这样开发人员就可以把对数据库的操作转化为对这些对象的操作.我们 ...
- 去掉NSString中的HTML标签
经常出现字符串带有html标签.下面有个方法一步到位去掉HTML标签 <span style="font-family: 'comic sans ms', sans-serif; co ...
- java中图片文件的判断
javax.imageio 类 ImageIO BufferedImage bi = ImageIO.read(resFile);//resFile --- InputStream if(bi == ...
- 想从事分布式系统,计算,hadoop等方面,需要哪些基础,推荐哪些书籍?--转自知乎
作者:廖君链接:https://www.zhihu.com/question/19868791/answer/88873783来源:知乎 分布式系统(Distributed System)资料 < ...
- linux主机间复制文件
命令基本格式: 1.从 本地 复制到 远程 * 复制文件: * 命令格式: scp local_file remote_username@re ...