分享好友 前端技术首页 频道列表

Angular 核心概念2

angular  2023-03-08 19:190

自定义指令

  • 指令增强了 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属性可以定义指令的使用类型

    1. E:Element(元素)
    2. A:Attribute(属性)
    3. C:Class(类名)
    4. 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"

作用

  • 多浏览器同时浏览
  • 代码热更新

其他

wappalyzer

查看更多关于【angular】的文章

展开全文
相关推荐
反对 0
举报 0
评论 0
图文资讯
热门推荐
优选好物
更多热点专题
更多推荐文章
Angular.js的作用域和数据绑定
初识Angular.js通过初识Angular.js可以做一个简单的入门,下面开始做深入的了解吧。作用域作用域($scope)和应用的数据模型相关联的,同时作用域也是表达式执行的上下文。$scope对象是定义应用业务逻辑、控制器方法和视图属性的地方。 作用域是视图和控制器

0评论2023-03-16944

angularJSapi学习-angular.copy使用
angular.copy使用效果:初始状态:输入信息后未保存状态:点击save后状态:当输入框内容和master内容不一致时:点击reset使得user的信息被重置为master中信息: 具体代码: 1 !DOCTYPE HTML 2 html ng-app="app" 3 headscript src="./angular.min.js"/script

0评论2023-03-16345

Angular.js之内置过滤器学习笔记 javascript过滤器
!DOCTYPE htmlhtml lang="en"headmeta charset="UTF-8"titleangularFilter/titlescript src="http://cdn.bootcss.com/angular.js/1.4.6/angular.js"/script/head  body ng-app="angularJS" ng-controller="ctrl"    div{{

0评论2023-03-08452

Angular 隨記
Windows下更新Node 和NPM方法管理員模式打開powershell執行以下命令:Set-ExecutionPolicy Unrestricted -Scope CurrentUser -Forcenpm install -g npm-windows-upgradenpm-windows-upgrade

0评论2023-03-08858

双向数据绑定(angular,vue) 双向数据绑定指令
最近github上插件项目更新了关于双向数据绑定的实现方式,关于angular和vue.angular众所周知是使用的脏检查($dirty)。一开始大家会认为angular开启了类似setInterval去不停的循环检查,性能极差,但其实并不是,$dirty是在一定条件下才会去执行,比如输入框

0评论2023-03-08953

angular.js使用ui-router注入报错,这里是版本问题导致的
 报错如下:common.ts:604Uncaught SyntaxError: Unexpected token ) stateEvents.ts:211Uncaught SyntaxError: Unexpected token ) jquery.js:3827 Uncaught Error: [$injector:modulerr] Failed to instantiate module salesApp due to: Error: [$injector

0评论2023-03-08406

angular5给懒加载模块添加loading angular2懒加载
在根组件的构造函数中直接执行:this.router.events.subscribe(event={if(event instanceof RouteConfigLoadEnd) {this.toast.hide();}if(event instanceof RouteConfigLoadStart) {this.toast.loading();} }); 

0评论2023-03-08610

mean(bootstrap,angular,express,node,mongodb)通用后台框架
学习node,我这个毫无美感的程序员在bootstrap与node的感染下,向着“全栈工程师”迈进,呵呵!最终选择如题的技术方案,这些东东都算比较新的,网上的资料比较少,参考了不少github程序及自己的努力,终于有一些感觉了,于是开贴记录一些感悟,供自己与同道

0评论2023-03-08393

Angular 核心概念
module(模块)作用通过模块对页面进行业务上的划分,根据不同的功能划分不同的模块。将重复使用的指令或者过滤器之类的代码做成模块,方便复用注意必须指定第二个参数,否则变成找到已经定义的模块请参照资料-备课代码-20-module.html理解语法语法: angular.

0评论2023-03-08579

Angular框架 angular框架和vue框架的区别
Angular 框架库和框架的区别jQuery:库库一般都是封装了一些常用的方法自己手动去调用这些方法,来完成我们的功能$('#txt').val('我是小明');$('div').text('xx');angular:框架框架都是提供一种规范或者模式,我们却要按照它提供的这种规则去写代码框架会自动

0评论2023-03-08930

更多推荐