详解如何在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 相关文章推荐
js关闭当前页面(窗口)的几种方式总结
Mar 05 Javascript
JavaScript中的apply和call函数详解
Jul 20 Javascript
js中iframe调用父页面的方法
Oct 30 Javascript
关于延迟加载JavaScript
May 05 Javascript
js实现跨域的多种方法
Dec 25 Javascript
Vue.js实战之通过监听滚动事件实现动态锚点
Apr 04 Javascript
详解webpack+vue-cli项目打包技巧
Jun 17 Javascript
vue的diff算法知识点总结
Mar 29 Javascript
Node.js事件的正确使用方法
Apr 05 Javascript
vue路由守卫及路由守卫无限循环问题详析
Sep 05 Javascript
Js Snowflake(雪花算法)生成随机ID的实现方法
Aug 26 Javascript
如何在CocosCreator里画个炫酷的雷达图
Apr 16 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+mysql写的留言本
2006/10/09 PHP
PHP 编写的 25个游戏脚本
2009/05/11 PHP
提升PHP性能的21种方法介绍
2013/06/25 PHP
Laravel使用PHPQRCODE实现生成带有LOGO的二维码图片功能示例
2017/07/07 PHP
PHP实现的折半查询算法示例
2017/10/09 PHP
Laravel框架生命周期与原理分析
2018/06/12 PHP
PHP实现笛卡尔积算法的实例讲解
2019/12/22 PHP
JavaScript Event学习第二章 Event浏览器兼容性
2010/02/07 Javascript
js字符串的各种格式的转换 ToString,Format
2011/08/08 Javascript
用jquery实现的一个超级简单的下拉菜单
2014/05/18 Javascript
jQuery中$.each使用详解
2015/01/29 Javascript
js常用的继承--组合式继承
2017/03/06 Javascript
基于AngularJS的简单使用详解
2017/09/10 Javascript
VsCode新建VueJs项目的详细步骤
2017/09/23 Javascript
vue技术分享之你可能不知道的7个秘密
2018/04/09 Javascript
layerUI下的绑定事件实例代码
2018/08/17 Javascript
微信小程序自定义轮播图
2018/11/04 Javascript
详解vue-cli@2.x项目迁移日志
2019/06/06 Javascript
详解JS函数防抖
2020/06/05 Javascript
python通过索引遍历列表的方法
2015/05/04 Python
numpy中实现ndarray数组返回符合特定条件的索引方法
2018/04/17 Python
Python Pandas中根据列的值选取多行数据
2019/07/08 Python
tensorflow之获取tensor的shape作为max_pool的ksize实例
2020/01/04 Python
Python爬虫爬取电影票房数据及图表展示操作示例
2020/03/27 Python
Python文件名匹配与文件复制的实现
2020/12/11 Python
CSS3教程:边框属性border的极致应用
2009/04/02 HTML / CSS
Solid & Striped官网:美国泳装品牌
2019/06/19 全球购物
完美实现CSS垂直居中的11种方法
2021/03/27 HTML / CSS
环境工程毕业生自荐信
2013/11/17 职场文书
美德少年事迹材料
2014/01/23 职场文书
劳动仲裁调解书
2015/05/20 职场文书
2016年清明节期间群众祭祀活动工作总结
2016/04/01 职场文书
小程序后台PHP版本部署运行 LNMP+WNMP
2021/04/01 Servers
DIY胆机必读:各国电子管评价
2022/04/06 无线电
阿里云日志过滤器配置日志服务
2022/04/09 Servers
IDEA中sout快捷键无效问题的解决方法
2022/07/23 Java/Android