详解如何在angular2中获取节点


Posted in Javascript onNovember 23, 2017

我们知道在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]+'离开'); 





} 




}); 



}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
基于Jquery的表格隔行换色,移动换色,点击换色插件
Dec 22 Javascript
让ie6也支持websocket采用flash封装实现
Feb 18 Javascript
jquery实现页面虚拟键盘特效
Aug 08 Javascript
Angularjs过滤器使用详解
May 25 Javascript
Javascript单例模式的介绍和实例
Oct 08 Javascript
vue-cli webpack 开发环境跨域详解
May 18 Javascript
vue高德地图之玩转周边
Jun 16 Javascript
jQuery remove()过滤被删除的元素(推荐)
Jul 18 jQuery
JavaScript中的return布尔值的用法和原理解析
Aug 14 Javascript
vue+axios+mock.js环境搭建的方法步骤
Aug 28 Javascript
浅谈JS中this在各个场景下的指向
Aug 14 Javascript
vue中keep-alive、activated的探讨和使用详解
Jul 26 Javascript
Vuejs中使用markdown服务器端渲染的示例
Nov 22 #Javascript
浅谈Vue-cli 命令行工具分析
Nov 22 #Javascript
JavaScript数据结构与算法之队列原理与用法实例详解
Nov 22 #Javascript
深入理解Vue官方文档梳理之全局API
Nov 22 #Javascript
初识 Vue.js 中的 *.Vue文件
Nov 22 #Javascript
chorme 浏览器记住密码后input黄色背景处理方法(两种)
Nov 22 #Javascript
基于JavaScript实现表格滚动分页
Nov 22 #Javascript
You might like
php基础知识:类与对象(5) static
2006/12/13 PHP
php下将XML转换为数组
2010/01/01 PHP
PHP中遍历stdclass object的实现代码
2011/06/09 PHP
PHP 异步执行方法,模拟多线程的应用分析
2013/06/03 PHP
php指定函数参数默认值示例代码
2013/12/04 PHP
php生成随机密码自定义函数代码(简单快速)
2014/05/10 PHP
php使用function_exists判断函数可用的方法
2014/11/19 PHP
php实现的网络相册图片防盗链完美破解方法
2015/07/01 PHP
PHP编写登录验证码功能 附调用方法
2016/05/19 PHP
PHP获取当前执行php文件名的代码
2017/03/02 PHP
php简单读取.vcf格式文件的方法示例
2017/09/02 PHP
PHP实现超简单的SSL加密解密、验证及签名的方法示例
2017/08/28 PHP
(function(){})()的用法与优点
2007/03/11 Javascript
JS面向对象编程之对象使用分析
2010/08/19 Javascript
理解Javascript图片预加载
2016/02/23 Javascript
微信小程序 scroll-view实现上拉加载与下拉刷新的实例
2017/01/21 Javascript
微信小程序 合法域名校验出错详解及解决办法
2017/03/09 Javascript
JavaScript无缝滚动效果的实例代码
2017/03/27 Javascript
很棒的vue弹窗组件
2017/05/24 Javascript
vue.js国际化 vue-i18n插件的使用详解
2017/07/07 Javascript
Nuxt.js开启SSR渲染的教程详解
2018/11/30 Javascript
微信小程序iOS下拉白屏晃动问题解决方案
2019/10/12 Javascript
vue 避免变量赋值后双向绑定的操作
2020/11/07 Javascript
[06:20]2015国际邀请赛第三日top10
2015/08/08 DOTA
[50:12]EG vs Fnatic 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
Python实现的简单模板引擎功能示例
2017/09/02 Python
通过python+selenium3实现浏览器刷简书文章阅读量
2017/12/26 Python
python kmeans聚类简单介绍和实现代码
2018/02/23 Python
python实时检测键盘输入函数的示例
2019/07/17 Python
python实现连连看辅助之图像识别延伸
2019/07/17 Python
pytorch多进程加速及代码优化方法
2019/08/19 Python
怎样声明接口
2014/09/19 面试题
Java中各种基本数据类型的默认值都是什么
2016/12/22 面试题
建筑工地标语
2014/06/18 职场文书
学校社团活动总结
2015/05/07 职场文书
太行山上观后感
2015/06/05 职场文书