当前位置: 移动技术网 > IT编程>脚本编程>AngularJs > 详解如何在angular2中获取节点

详解如何在angular2中获取节点

2017年12月08日  | 移动技术网IT编程  | 我要评论
我们知道在angular2中ts文件支持js代码,为什么用document.getelementbyid没法获取元素节点呢? 其实在angular2中先加载ts文件,再加

我们知道在angular2中ts文件支持js代码,为什么用document.getelementbyid没法获取元素节点呢?

其实在angular2中先加载ts文件,再加载view,所以获取不到节点。

在应用层直接操作 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 divele =this.elementref.nativeelement.queryselector('div');//获取第一个div

  console.dir(divele);

  let div = doxcument.getelementbyid("div");  //获取id为‘div'的节点

}

}

下面有一种优化方案,运用angular内置属性装饰器@viewchild

ts:

import{ component, elementref, viewchild, afterviewinit }from'@angular/core';

exportclassappcomponent{

@viewchild('greet')

 greetdiv: elementref;

ngafterviewinit() {this.greetdiv.nativeelement.style.backgroundcolor ='red'; }

}

html:

<div #greet>hello world</div>  //element的标识"#name",@viewchild根据这个搜索元素

angular中怎么获取dom元素

步骤分解:

第一步:给要获取的元素一个ng-model变量,并且绑定事件啦!

复制代码 代码如下:

<div class="home" ng-model="dirname"  ng-mouseenter="switchimage($event,dirname)"></div>  //给要获取的元素一个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]+'离开'); 
          } 
        }); 
      }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网