详解如何在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 目录列举函数
Nov 06 Javascript
修改jQuery Validation里默认的验证方法
Feb 14 Javascript
javascript针对DOM的应用分析(三)
Apr 15 Javascript
深入分析escape()、encodeURI()、encodeURIComponent()的区别及示例
Aug 04 Javascript
jQuery中addClass()方法用法实例
Jan 05 Javascript
javascript实现简单加载随机色方块
Dec 25 Javascript
使用jquery提交form表单并自定义action的实现代码
May 25 Javascript
Angularjs中ng-repeat-start与ng-repeat-end的用法实例介绍
Dec 31 Javascript
jQuery手风琴的简单制作
May 12 jQuery
Vue-router 类似Vuex实现组件化开发的示例
Sep 15 Javascript
微信小程序里引入SVG矢量图标的方法
Sep 20 Javascript
解决layui页面按钮点击无反应,也不报错的问题
Sep 29 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
德生BCL3000的电路分析和打磨
2021/03/02 无线电
用PHP实现多级树型菜单
2006/10/09 PHP
PHP实现的sqlite数据库连接类
2014/12/12 PHP
php+xml编程之xpath的应用实例
2015/01/24 PHP
对比PHP对MySQL的缓冲查询和无缓冲查询
2016/07/01 PHP
PHP生成图像验证码的方法小结(2种方法)
2016/07/18 PHP
一个字符串中出现次数最多的字符 统计这个次数【实现代码】
2016/04/29 Javascript
通用无限极下拉菜单的实现代码
2016/05/31 Javascript
给easyui的datebox控件添加清空按钮的实现方法
2016/11/09 Javascript
JavaScript之cookie技术详解
2016/11/18 Javascript
jquery拖动改变div大小
2017/07/04 jQuery
bootstrap精简教程_动力节点Java学院整理
2017/07/14 Javascript
详解tween.js 中文使用指南
2018/01/05 Javascript
JavaScript折半查找(二分查找)算法原理与实现方法示例
2018/08/06 Javascript
傻瓜式vuex语法糖kiss-vuex整理
2018/12/21 Javascript
vue模块拖拽实现示例代码
2019/03/09 Javascript
js实现拖拽元素选择和删除
2020/08/25 Javascript
vue 将多个过滤器封装到一个文件中的代码详解
2020/09/05 Javascript
javascript canvas实现简易时钟例子
2020/09/05 Javascript
python有证书的加密解密实现方法
2014/11/19 Python
CentOS下Python3的安装及创建虚拟环境的方法
2018/11/28 Python
在python tkinter中Canvas实现进度条显示的方法
2019/06/14 Python
django-allauth入门学习和使用详解
2019/07/03 Python
Python爬虫 bilibili视频弹幕提取过程详解
2019/07/31 Python
在Python中画图(基于Jupyter notebook的魔法函数)
2019/10/28 Python
python从zip中删除指定后缀文件(推荐)
2019/12/05 Python
推荐8款常用的Python GUI图形界面开发框架
2020/02/23 Python
Python3以GitHub为例来实现模拟登录和爬取的实例讲解
2020/07/30 Python
如何用用Python将地址标记在地图上
2021/02/07 Python
出售房屋协议书范本
2014/10/06 职场文书
幼儿园2014年度工作总结
2014/11/10 职场文书
2015年机关党委工作总结
2015/05/23 职场文书
2015年行政执法工作总结
2015/05/23 职场文书
王亚平太空授课观后感
2015/06/12 职场文书
《别在吃苦的年纪选择安逸》读后感3篇
2019/11/30 职场文书
使用Python+OpenCV进行卡类型及16位卡号数字的OCR功能
2021/08/30 Python