Angular.JS如何通过指令操作DOM-创新互联
这篇文章给大家分享的是有关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监听器,同时更新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”))
感谢各位的阅读!关于“Angular.JS如何通过指令操作DOM”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
文章名称:Angular.JS如何通过指令操作DOM-创新互联
新闻来源:http://azwzsj.com/article/dscedd.html