您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

在angular2中获取节点的方法

2025/3/22 9:48:11发布57次查看
在angular2中ts文件支持js代码,为什么用document.getelementbyid没法获取元素节点呢?其实在angular2中先加载ts文件,再加载view,所以获取不到节点。本文主要介绍了如何在angular2中获取节点,详细的介绍了几种方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。
在应用层直接操作 dom,就会造成应用层与渲染层之间强耦合,导致我们的应用无法运行在不同环境,如 web worker 中,因为在 web worker 环境中,是不能直接操作 dom。
通过 elementref 我们就可以封装不同平台下视图层中的 native 元素 (在浏览器环境中,native 元素通常是指 dom 元素),最后借助于 angular 提供的强大的依赖注入特性,我们就可以轻松地访问到 native 元素。
angular2有生命周期钩子afterviewinit可以帮助我们在view加载完之后再执行相应的ts
ts:
import { component, elementref ,afterviewinit} from '@angular/core'; exportclassappcomponent { constructor(privateelementref: elementref) { } ngafterviewinit() { let pele =this.elementref.nativeelement.queryselector('p');//获取第一个p console.dir(pele); let p = doxcument.getelementbyid("p"); //获取id为‘p'的节点 } }
下面有一种优化方案,运用angular内置属性装饰器@viewchild
ts:
import{ component, elementref, viewchild, afterviewinit }from'@angular/core'; exportclassappcomponent{ @viewchild('greet') greetp: elementref; ngafterviewinit() {this.greetp.nativeelement.style.backgroundcolor ='red'; } }
html:
<p #greet>hello world</p> //element的标识"#name",@viewchild根据这个搜索元素
angular中怎么获取dom元素
步骤分解:
第一步:给要获取的元素一个ng-model变量,并且绑定事件啦!
复制代码 代码如下:
<p class="home" ng-model="dirname" ng-mouseenter="switchimage($event,dirname)"></p> //给要获取的元素一个ng-model变量
第二步:在controller中利用$event.target获取dom元素即可!
$scope.switchimage = function($event, value) { 3 $($event.target).on("mouseenter mouseleave",function(e) { var w = $(this).width(); // 得到盒子宽度 var h = $(this).height();// 得到盒子高度 var x = (e.pagex - this.offsetleft - (w / 2)) * (w > h ? (h / w) : 1); // 获取x值 var y = (e.pagey - this.offsettop - (h / 2)) * (h > w ? (w / h) : 1); // 获取y值 var direction = math.round((((math.atan2(y, x) * (180 / math.pi)) + 180) / 90) + 3) % 4; //direction的值为“0,1,2,3”分别对应着“上,右,下,左” // 将点的坐标对应的弧度值换算成角度度数值 var dirname = new array('上方','右侧','下方','左侧'); if(e.type == 'mouseenter' && direction == 1){ $(this).find('.profil-photo').html(dirname[direction]+'离开'); }else{  $(this).find('.profil-photo').html(dirname[direction]+'离开'); } }); }
相关推荐:
js获取节点的兄弟,父级,子级元素的方法_javascript技巧
jquery获取节点和子节点文本的方法_jquery
jquery获取节点名称_jquery
以上就是在angular2中获取节点的方法的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product