详解如何在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 相关文章推荐
理解Javascript_10_对象模型
Oct 16 Javascript
JavaScript拖拽、碰撞、重力及弹性运动实例分析
Jan 08 Javascript
第三章之Bootstrap 表格与按钮功能
Apr 25 Javascript
Javascript 对cookie操作详解及实例
Dec 29 Javascript
Javascript for in的缺陷总结
Feb 03 Javascript
Angular2自定义分页组件
Apr 19 Javascript
Vue2.0基于vue-cli+webpack父子组件通信(实例讲解)
Sep 14 Javascript
javascript基本常用排序算法解析
Sep 27 Javascript
vue中实现图片和文件上传的示例代码
Mar 16 Javascript
AngularJS ui-router刷新子页面路由的方法
Jul 23 Javascript
vue中利用simplemde实现markdown编辑器(增加图片上传功能)
Apr 29 Javascript
JQuery事件委托(适用于给动态生成的脚本元素添加事件)
Feb 01 jQuery
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文件向另一个地址post数据,不用表单和隐藏的变量的
2007/03/06 PHP
PHP7新特性之抽象语法树(AST)带来的变化详解
2018/07/17 PHP
PHP字符串与数组处理函数用法小结
2020/01/07 PHP
JS提交并解析后台返回的XML的代码
2008/11/03 Javascript
JQuery实现的在新窗口打开链接的方法小结
2010/04/22 Javascript
Jquery创建一个层当鼠标移动到层上面不消失效果
2013/12/12 Javascript
关于延迟加载JavaScript
2015/05/05 Javascript
javascript比较语义化版本号的实现代码
2016/09/09 Javascript
关于RequireJS的简单介绍即使用方法
2016/10/20 Javascript
js仿微信语音播放实现思路
2016/12/12 Javascript
w3c编程挑战_初级脚本算法实战篇
2017/06/23 Javascript
Node.js+jade抓取博客所有文章生成静态html文件的实例
2017/09/19 Javascript
微信小程序loading组件显示载入动画用法示例【附源码下载】
2017/12/09 Javascript
vue解决使用webpack打包后keep-alive不生效的方法
2018/09/01 Javascript
微信小程序使用自定义组件导航实现当前页面高亮
2020/01/02 Javascript
[54:10]完美世界DOTA2联赛PWL S2 Magma vs FTD 第二场 11.29
2020/12/03 DOTA
python中精确输出JSON浮点数的方法
2014/04/18 Python
Python二分法搜索算法实例分析
2015/05/11 Python
django轻松使用富文本编辑器CKEditor的方法
2017/03/30 Python
浅谈Python反射 &amp; 单例模式
2019/03/21 Python
查看python安装路径及pip安装的包列表及路径
2019/04/03 Python
Python 通过打码平台实现验证码的实现
2019/05/13 Python
numpy中三维数组中加入元素后的位置详解
2019/11/28 Python
Python操作MongoDb数据库流程详解
2020/03/05 Python
keras中epoch,batch,loss,val_loss用法说明
2020/07/02 Python
Vs Code中8个好用的python 扩展插件
2020/10/12 Python
Python如何使用ConfigParser读取配置文件
2020/11/12 Python
HTML5的Video标签有部分MP4无法播放的问题解析(多图)
2017/08/18 HTML / CSS
享誉全球的多元化时尚精品购物平台:Farfetch发发奇(支持中文)
2017/08/08 全球购物
美国时尚在线:Showpo
2017/09/08 全球购物
婚礼证婚人证婚词
2014/01/08 职场文书
理财投资建议书
2014/03/12 职场文书
收款委托书
2014/10/14 职场文书
销售业务员岗位职责
2015/02/13 职场文书
2015年教务处干事工作总结
2015/07/22 职场文书
Spring Boot配合PageHelper优化大表查询数据分页
2022/04/20 Java/Android