详解如何在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 sortable效果 代码有错但值得看看
Nov 05 Javascript
jQuery判断元素是否存在的可靠方法
May 06 Javascript
JavaScript常用数组算法小结
Feb 13 Javascript
jqueryMobile 动态添加元素,展示刷新视图的实现方法
May 28 Javascript
AngularJS ng-bind 指令简单实现
Jul 30 Javascript
JS中setTimeout和setInterval的最大延时值详解
Feb 13 Javascript
JavaScript数据结构之数组的表示方法示例
Apr 12 Javascript
微信小程序之购物车功能
Sep 23 Javascript
Nuxt.js实现校验访问浏览器类型的中间件
Aug 24 Javascript
使用异步controller与jQuery实现卷帘式分页
Jun 18 jQuery
javascript-hashchange事件和历史状态管理实例分析
Apr 18 Javascript
JS实现简单打字测试
Jun 24 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
ThinkPHP采用原生query实现关联查询left join实例
2014/12/02 PHP
针对多用户实现头像上传功能PHP代码 适用于登陆页面制作
2016/08/17 PHP
解决出现SoapFault (looks like we got no XML document)的问题
2017/06/24 PHP
CakePHP框架Model函数定义方法示例
2017/08/04 PHP
用javascript获得地址栏参数的两种方法
2006/11/08 Javascript
jQuery温习篇 强大的JQuery选择器
2010/04/24 Javascript
jquery学习笔记 用jquery实现无刷新登录
2011/08/08 Javascript
appendChild() 或 insertBefore()使用与区别介绍
2013/10/11 Javascript
JS随机漂浮广告代码具体实例
2013/11/19 Javascript
jQuery模拟点击A标记示例参考
2014/04/17 Javascript
node.js中的fs.futimes方法使用说明
2014/12/17 Javascript
JavaScript对象反射用法实例
2015/04/17 Javascript
详解JavaScript中数组的reduce方法
2016/12/02 Javascript
react.js 获取真实的DOM节点实例(必看)
2017/04/17 Javascript
mongoose更新对象的两种方法示例比较
2017/12/19 Javascript
koa2实现登录注册功能的示例代码
2018/12/03 Javascript
Javascript三种字符串连接方式及性能比较
2019/05/28 Javascript
layui table数据修改的回显方法
2019/09/04 Javascript
使用 Opentype.js 生成字体子集的实例代码详解
2020/05/25 Javascript
[16:19]教你分分钟做大人——风暴之灵
2015/03/11 DOTA
python实现红包裂变算法
2016/02/16 Python
Python贪吃蛇游戏编写代码
2020/10/26 Python
Linux下多个Python版本安装教程
2018/08/15 Python
Python开发之Nginx+uWSGI+virtualenv多项目部署教程
2019/05/13 Python
python with (as)语句实例详解
2020/02/04 Python
解决python 执行sql语句时所传参数含有单引号的问题
2020/06/06 Python
Python中如何添加自定义模块
2020/06/09 Python
前端面试必备之html5的新特性
2017/09/05 HTML / CSS
html5与css3小应用
2013/04/03 HTML / CSS
澳大利亚领先的在线机械五金、园艺和存储专家:Edisons
2018/03/24 全球购物
Bally美国官网:经典瑞士鞋履、手袋及配饰奢侈品牌
2018/05/18 全球购物
xml有哪些解析技术?区别是什么
2016/04/26 面试题
业务员的岗位职责
2014/03/15 职场文书
学校领导班子群众路线整改措施
2014/09/16 职场文书
幼儿园工作总结2015
2015/04/01 职场文书
2015年中学图书馆工作总结
2015/07/22 职场文书