AngularJS 笔记

自定义指令 scope 的属性参数 &

var app = angular.module('app',[]);
app.controller('xmgController',['$scope',function($scope){
        $scope.name = 'father-name';
        $scope.fatherAge = 'father-age';
        $scope.fatherMethod = function(){
              alert('执行了父方法 fatherMethod');
        }
}]);
app.directive('gxq',function(){
        return {
                restrict:'EA';
                template:'<h1>{{name}}</h1><p ng-click = 'show()'>点我</p>',
                conteroller:function($scope){
                        
                },
                scope:{
                        name:'@',
                        age:'=',
                        //要求外界传递信息(父方法进来)
                        show:'&'
                }
        }
});
<body ng-app="app" ng-controller="xmgController">
        <input type='text' ng-model="name">
        <h1>{{name}}</h1>
        <input type ="text" ng-model ="fatherAge">
        <h1>{{fatherAge}}</h1>
        <hr>
        <div gxq name="{{name}}" age="fatherAge" show="fatherMethod()"></div>
</body>

自定义指令中的 Link 属性

  app.directive('gxq',function () {
           return {
               restrict:'EA',
               template:'<div><h1 ng-click="hello()">hello</h1> <p ng-click="show()">点我</p></div>',
               replace:true,
               controller:function ($scope) { //一般都是处理业务逻辑

               },
               link:function ($scope,ele,attr) { //一般都是处理dom元素。
                   var res = attr.xmgShow;
                   if (res == 'false'){
                       ele.css({
                           'display':'none'
                       });
                   }
               },
               //scope:true //与父作用域是同一个
               scope:{
                   show:'&',   //1.show="父方法名称()"
                   hello:'&'
               }
           }

        });


    </script>
</head>
<body ng-app="app" ng-controller="xmgController">
<button ng-click="fatherMothod()">父点击</button>

<hr>

<!--<div gxq  show="fatherMothod()" hello="fatherHello()"></div>-->
<gxq xmg-show="true"></gxq>



</body>

jQLite 对象

  • AngularJS 中包含了一部分 jQuery 功能
  • 如果说已经引入了 jquery 那么使用 angular.element(box);获取的对象就是一个原生 jquery 对象
  • 要想使用 jquery 的全部方法需要先引用 jquery 文件 然后引用 angularjs 文件
var box = document.querySelector('.box');
var btn = document.querySelector('.btn');
box = angular.element(box);
btn = angular.element(btn);
box.css({
    width:'100px',
    height:'100px',
    background:'red'
})
//无效果,angular内封装的 jquery 没有这个方法
btn.on('click',function(){
    box.animate({
            width:'300px',
            height:'300px'
    })
})

$watch 监听

    <script src="angular1.6.js"></script>
    <script>
        //1.创建模板
        var app = angular.module('app', []);
        //2.创建控制器
        app.controller('xmgController', ['$scope', function ($scope) {
            $scope.name = 'xmg';

            //$watch('scop身上的属性',fun(newV,oldV))
            //当属性值改变时,会自动调用回调方法。newV:改过之后最新的值。oldV:修改之前的值。
            /*$scope.$watch('per.name',function (newV,oldV) {
                console.log(newV+'-----'+oldV);
            });*/

            //默认情况下是不能直接监听对象。
            //如果想要监听一个对象,加上第三个参数true  为true可以监听对象的变化。
            //$watch很浪费性能。
            /*$scope.$watch('per',function (newV,oldV) {
                console.log(newV+'-----'+oldV);
            },true);*/

            //如何取消一个watch监听。
            //在调用$watch会返回一个方法。想要取消监听,直接执行返回的方法 即可。

            var count = 3;
            var unWatch = $scope.$watch('per.name',function (newV,oldV) {
                console.log(newV+'-----'+oldV);
                count--;
                if (count == 0){
                    unWatch();//取消监听。
                }
            },true);







        }]);
        //3.绑定模块
        //4.绑定控制器

    </script>
</head>

<body ng-app="app" ng-controller="xmgController">
<input type="text" ng-model="per.name">
<input type="text" ng-model="per.age">
<h1>{{per.name}}</h1>
<h1>{{per.age}}</h1>

</body>

$q 可以理解为 条件执行

      //1.创建模板
        var app = angular.module('app', []);
        //2.创建控制器
        app.controller('xmgController', ['$scope','$http','$q', function ($scope,$http,$q) {

            var defer = $q.defer();

            $http({
                url:'url',
                method:'get',
            }).then(function (res) {
                defer.resolve(res);
            }).catch(function (error) {
                defer.reject(error);
            });

            defer.promise.then(function (res) {
                //resolve
                alert(res);
            },function (error) {
                //reject
                alert('error'+error);
            }).finally(function () {
                //finally一定会执行。
                alert('fin');
            });


        }]);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,053评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,527评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,779评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,685评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,699评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,609评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,989评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,654评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,890评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,634评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,716评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,394评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,976评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,950评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,191评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,849评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,458评论 2 342

推荐阅读更多精彩内容