在指令而非在控制器中操作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監聽器,同時更新DOM,更多link-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”))
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對錯新站長站的支持。
新聞熱點
疑難解答
圖片精選