$sanitize和$sce服务的使用方法

$sanitize会把标签的属性都移除,以及绑定在元素上的事件.仅保留了标签和内容

$q服务的使用
1. 创建一个Service,去服务器读取数据:

2. 在Controller上(以同步方式)使用这个Service:

angular多个控制器如何共享数据 

多个控制器之间共享数据,通常两种方式:

第一种是在控制器里通过$scope.$$prevSibling或$scope.$$nextSibling获得另一个控制器的作用域对象。(这种共享数据的方法不推荐,应该使用服务来共享数据)

第二种是通过服务的方式,也是推荐的方式,不过值得注意的是,这两种方式的原理都是 利用对象的赋值是通过指针引用的

 在模块中定义服务

angular的$http配置属性

$http请求的配置对象

$http()接受的配置对象可以包含以下属性:

  method: http请求方式,可以为GET,DELETE,HEAD,JSONP,POST,PUT

  url: 字符串,请求的目标

  params: 字符串或者对象,会被转换成为查询字符串追加的url后面

  data: 在发送post请求时使用,作为消息体发送到服务器

  headers: 一个列表,每个元素都是一个函数,返回http头

  xsrfHeaderName(字符串):保存XSFR令牌的http头的名称

  xsrfCookieName: 保存XSFR令牌的cookie名称

  transformRequest: 函数或者函数数组,用来对http请求的请求体和头信息进行转换,并返回转换后的结果。

  transformResponse: 函数或者函数数组,用来对http响应的响应体和头信息进行转换,并返回转换后的结果。

  cache: 布尔类型或者缓存对象,设置之后angular会缓存get请求。

  timeout:数值,延迟请求

  responseType:字符串,响应类型。可以为arraybuffer, blob,document,json, text, moz-blob, moz-chunked-text, moz-chunked-arraybuffer

$http请求的响应对象

angular传递给then方法的响应对象包括以下几个属性

  data: 转换之后的响应体

  status: http响应状态码

  headers: 头信息

  config: 生成原始请求的设置对象

  statusText: http响应状态的文本

 封装第三方jquery插件

自己编写 directive 的情况通常是当你使用了第三方的 jQuery 插件,因为插件在 AngularJS 之外对表单值进行更改,并不能即时反应到 Model 中。

例如,我们用得比较多的 jQueryUI datepicker 插件,当你选中一个日期后,插件会将日期字符串填到 input 输入框中。View 改变了,却并没有更新 Model,因为$('.datepicker').datepicker(); 这段代码不属于 AngularJS 的管理范围。

我们需要编写一个directive 来让 DOM 的改变即时更新到 Model 里。

然后在 HTML 中引入这个 directive

<input type="text" datepicker ng-model="myObject.myDateValue" />

AngularJS操作DOM - angular.element

  addClass()-为每个匹配的元素添加指定的样式类名
  after()-在匹配元素集合中的每个元素后面插入参数所指定的内容,作为其兄弟节点
  append()-在每个匹配元素里面的末尾处插入参数内容
  attr() - 获取匹配的元素集合中的第一个元素的属性的值
  bind() - 为一个元素绑定一个事件处理程序
  children() - 获得匹配元素集合中每个元素的子元素,选择器选择性筛选
  clone()-创建一个匹配的元素集合的深度拷贝副本
  contents()-获得匹配元素集合中每个元素的子元素,包括文字和注释节点
  css() - 获取匹配元素集合中的第一个元素的样式属性的值
  data()-在匹配元素上存储任意相关数据
  detach()-从DOM中去掉所有匹配的元素
  empty()-从DOM中移除集合中匹配元素的所有子节点
  eq()-减少匹配元素的集合为指定的索引的哪一个元素
  find() - 通过一个选择器,jQuery对象,或元素过滤,得到当前匹配的元素集合中每个元素的后代
  hasClass()-确定任何一个匹配元素是否有被分配给定的(样式)类
  html()-获取集合中第一个匹配元素的HTML内容
  next() - 取得匹配的元素集合中每一个元素紧邻的后面同辈元素的元素集合。如果提供一个选择器,那么只有紧跟着的兄弟元素满足选择器时,才会返回此元素
  on() - 在选定的元素上绑定一个或多个事件处理函数
  off() - 移除一个事件处理函数
  one() - 为元素的事件添加处理函数。处理函数在每个元素上每种事件类型最多执行一次
  parent() - 取得匹配元素集合中,每个元素的父元素,可以提供一个可选的选择器
  prepend()-将参数内容插入到每个匹配元素的前面(元素内部)
  prop()-获取匹配的元素集中第一个元素的属性(property)值
  ready()-当DOM准备就绪时,指定一个函数来执行
  remove()-将匹配元素集合从DOM中删除。(同时移除元素上的事件及 jQuery 数据。)
  removeAttr()-为匹配的元素集合中的每个元素中移除一个属性(attribute)
  removeClass()-移除集合中每个匹配元素上一个,多个或全部样式
  removeData()-在元素上移除绑定的数据
  replaceWith()-用提供的内容替换集合中所有匹配的元素并且返回被删除元素的集合
  text()-得到匹配元素集合中每个元素的合并文本,包括他们的后代
  toggleClass()-在匹配的元素集合中的每个元素上添加或删除一个或多个样式类,取决于这个样式类是否存在或值切换属性。即:如果存在(不存在)就删除(添加)一个类
  triggerHandler() -为一个事件执行附加到元素的所有处理程序
  unbind() - 从元素上删除一个以前附加事件处理程序
  val()-获取匹配的元素集合中第一个元素的当前值
  wrap()-在每个匹配的元素外层包上一个html元素

 

angualrjs 总结 随记(三)的更多相关文章

  1. Java入门记(三):初始化顺序

    初始化顺序的规则 1.在一个类的对象实例化时,成员变量首先初始化,然后才调用构造器,无论书写顺序.如果调用构造器前,没有显式初始化,那么会赋默认值. 这样做法的原因可以理解为:构造器执行时可能会用到一 ...

  2. 【算法随记三】小半径中值模糊的急速实现(16MB图7.5ms实现) + Photoshop中蒙尘和划痕算法解读。

    在本人的博客里,分享了有关中值模糊的O(1)算法,详见:任意半径中值滤波(扩展至百分比滤波器)O(1)时间复杂度算法的原理.实现及效果 ,这里的算法的执行时间和参数是无关的.整体来说,虽然速度也很快, ...

  3. MVC4学习要点记三

    一.数据迁移用来解决code first情况下当增加.删除.改变实体类,或改变DbContext类后,相应地更新数据库结构而不会对现有数据产生影响. 1.启用迁移指令:enable-migration ...

  4. angualrjs 总结 随记(一)

    $apply方法的作用 $apply方法是用来触发脏检查,它在控制器里监听一个变量,每当这个变量的值改变的时候,它会去与最初的值做一次比较,然后HTML页面就会及时更新该变量的值(将最新的值赋值到ht ...

  5. crm踩坑记(三)

    React 如何同步更新state 由于setState方法是异步的,而通常很多时候在一个生命周期里更新state后需要在另一个生命周期里使用这个state. 下面介绍几个方法 // 1 this.s ...

  6. (NO.00003)iOS游戏简单的机器人投射游戏成形记(三)

    接下来我们建立机器人对象. 在Sprites文件夹中新建Robot.ccb文件,类型为Node. 打开SpriteBuilder的Tileless View将机器人身体和手臂拖入根节点,调整好相对的位 ...

  7. (NO.00001)iOS游戏SpeedBoy Lite成形记(三十):增加排行榜功能3

    在这个例子中,我们的显示代码只需要选手的名字以及对应的成绩.根据选手名字取对应的成绩可以用前面实现的playerRecord:方法,我们只需要将按照成绩排序后的选手名字返回就可以了. 我只需要再实现一 ...

  8. (NO.00001)iOS游戏SpeedBoy Lite成形记(三)

    在Xcode中建立新类Player,继承自CCSprite.因为我们之后需要方便的更换玩家的大头贴,所以需要能够以不同的大头贴参数初始化Player对象. 不过别急,想想我们还需要在Player对象初 ...

  9. SQL随记(三)

    1.关于package: 包的作用:可以将任何出现在块声明的语句(过程,函数,游标,游标,类型,变量)放入包中,相当于一个容器. 包的好处:在包中的(过程,函数,游标,游标,类型,变量)相当于sql/ ...

随机推荐

  1. Spring 中的 JDBCTemplate

    新建一个java工程 写好spring配置文件,直接上代码 <?xml version="1.0" encoding="UTF-8"?> <b ...

  2. mabatis中的元素属性

    resultMap属性id 唯一标识type 返回类型extends 继承别的resultMap,可选关联其他标签id 设置主键使用,使用此标签配置映射关系(可能不止一个)result 一般属性的配置 ...

  3. git 学习 3

    远程仓库 添加远程库 GitHub 注册账号并建立 repository,Clone with SSH 1 $ ssh-keygen -t rsa -C "youremail@example ...

  4. 在CodaLab上提交MURA竞赛的结果

    What is MURA? MURA (musculoskeletal radiographs) is a large dataset of bone X-rays. Algorithms are t ...

  5. PAT B1080 MOOC期终成绩(C++)

    PAT甲级目录 | PAT乙级目录 题目描述 B1080 MOOC期终成绩 解题思路 可利用 map 将字符串型的学号转换为整型的序号,方便查找.输入全部成绩后,遍历每个学生同时计算最终成绩,然后将成 ...

  6. JAVA中对list map根据map某个key值进行排序

    package test; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; ...

  7. 如何正确使用redis分布式锁

    前言   笔者在公司担任技术面试官,在笔者面试过程中,如果面试候选人提到了reids分布式锁,笔者都会问一下redis分布式锁的知识点,但是令笔者遗憾的是,该知识点十个人中有九个人都答得不清楚,或者回 ...

  8. 聊聊RabbitMQ那一些事儿之一基础应用

    聊聊RabbitMQ那一些事儿之一基础应用 Hi,各位热爱技术的小伙伴您们好,今年的疫情害人啊,真心祝愿您和您的家人大家都平平安安,健健康康.年前到现在一直没有总结点东西,写点东西,不然久了自己感觉自 ...

  9. nvm安装以及注意事项

    nvm初衷:由于以后的开发工作可能会在多个Node版本中测试,而且Node的版本也比较多,所以需要这么款工具来管理 1. 下载:[nvm-windows](https://github.com/cor ...

  10. Css里的BFC

    一.BFC简介 BFC全称:Block Formatting Contexts (BFC,块级格式化上下文),就是 一个块级元素 的渲染显示规则 (可以把 BFC 理解为一个封闭的大箱子,,容器里面的 ...