亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Angular.JS通過指令操作DOM的方法

 更新時間:2017年05月10日 09:36:42   作者:劉小光  
這篇文章主要給大家介紹了Angular.JS通過指令操作DOM的方法,文中給出了詳細的介紹和示例代碼,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧。

在指令而非在控制器中操作DOM

相信大家在頁面處理中,難免會遇到操作DOM的情況,在AngularJS中,對DOM的操作是在指令而非控制器中完成的。

AngularJS強調隔離的思想:把復雜的邏輯和操作放在指令或服務中,控制器作為視圖和$scope之間的橋梁,僅僅用來存儲數據模型。

jqLite

為了便于DOM操作,AngularJS內部封裝了angular.element,如果現有項目中已經引入的jQuery,angular.element相當于jQuery函數的別名,否則,angular.element代表AngularJS對jQuery封裝的一個子集,稱為”jQuery lite”或者jqLite。jqLite不具備jQuery全部方法,詳見AngularJS官方文檔 angular.element。

link-function

link-function可以注冊DOM監(jiān)聽器,同時更新DOM,更多l(xiāng)ink-function介紹參考這篇文章AngularJS Custom-Directives link-function guide

指令代碼

一個引入jQuery操作DOM的指令如下:

webApp.directive("detailTopStick", ["$timeout", "$window", function ($timeout, $window) {
 return {
 restrict: "A",
 link: function (scope) {
 $timeout(function () {
 var navbar = $(".navbar-nav"); 
 var navbarOffsetTop = navbar.offset().top;
 var headerInfo = $(".header-info");
 var headerInfoMarginBottom = parseInt(headerInfo.css("margin-bottom"));
 var navbarHeight = parseInt(navbar.css("height"));
 
 angular.element($window).bind("resize", function () { // 窗口綁定resize事件
  navbar.css("width", headerInfo.width());
  navbarOffsetTop = navbar.offset().top;
  scope.$apply();
 });
 
 angular.element($window).bind("scroll", function () {
  if ($window.scrollY > navbarOffsetTop) {
  navbar.css("width", headerInfo.width());
  navbar.addClass("detail-navbar-fix");
  headerInfo.css("margin-bottom", headerInfoMarginBottom + navbarHeight);
  }
  else {
  navbar.removeClass("detail-navbar-fix");
  headerInfo.css("margin-bottom", headerInfoMarginBottom);
  }
  scope.$apply();
 });
 
 navbar.on("click", function () {
  if ($window.scrollY > navbarOffsetTop) {
  $window.scrollTo(0, navbarOffsetTop);
  }
 });
 });
 }
 };
}]);

如果未引入jquery,可以這樣獲取元素:angular.element(document.querySelector(“.class-name”))

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關文章

  • AngularJS指令用法詳解

    AngularJS指令用法詳解

    這篇文章主要介紹了AngularJS指令用法,較為詳細的分析了AngularJS指令的功能、用法及自定義指令的相關實現技巧,需要的朋友可以參考下
    2016-11-11
  • Angularjs自定義指令實現分頁插件(DEMO)

    Angularjs自定義指令實現分頁插件(DEMO)

    由于最近的一個項目使用的是angularjs1.0的版本,涉及到分頁查詢數據的功能,后來自己就用自定義指令實現了該功能,下面小編把實例demo分享到腳本之家平臺,需要的朋友參考下
    2017-09-09
  • angularjs實現與服務器交互分享

    angularjs實現與服務器交互分享

    AngularJS是Google開發(fā)的純客戶端JavaScript技術的WEB框架,用于擴展、增強HTML功能,它專為構建強大的WEB應用而設計。
    2014-06-06
  • Angular2中監(jiān)聽數據更新的方法

    Angular2中監(jiān)聽數據更新的方法

    今天小編就為大家分享一篇Angular2中監(jiān)聽數據更新的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • AngularJS教程之簡單應用程序示例

    AngularJS教程之簡單應用程序示例

    本文主要介紹AngularJS簡單應用程序,這里提供了詳細的流程和代碼程序,有需要的小伙伴可以參考下
    2016-08-08
  • Angular+Node生成隨機數的方法

    Angular+Node生成隨機數的方法

    這篇文章主要介紹了Angular+Node生成隨機數的方法,結合具體實例分析了Angular與Node結合控制前后端實現隨機數功能的相關操作技巧,需要的朋友可以參考下
    2017-06-06
  • 詳解AngularJS的通信機制

    詳解AngularJS的通信機制

    這篇文章主要介紹了AngularJS的通信機制,AngularJS是非常具有人氣的JavaScript庫,需要的朋友可以參考下
    2015-06-06
  • highcharts 在angular中的使用示例代碼

    highcharts 在angular中的使用示例代碼

    本篇文章主要介紹了highcharts 在angular中的使用示例代碼,非常具有實用價值,需要的朋友可以參考下
    2017-09-09
  • 基于angularjs實現圖片放大鏡效果

    基于angularjs實現圖片放大鏡效果

    這篇文章給大家分享了angularjs實現購物放大鏡效果的源碼實例,代碼介紹的很詳細,有需要的可以參考借鑒,下面來一起看看。
    2016-08-08
  • AngularJS 將再發(fā)布一個重要版本 然后進入長期支持階段

    AngularJS 將再發(fā)布一個重要版本 然后進入長期支持階段

    目前團隊正在開發(fā) AngularJS 1.7.0,而 1.7 的開發(fā)周期將一直持續(xù)到 2018 年 6 月 30 日
    2018-01-01

最新評論