时间:2021-05-25
我们知道在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元素即可!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
准备Angular2环境ng-bootstrap是基于Angular2的,因此需要先准备Angular2的环境。使用ng-bootstrap下载ng-boots
在这一章节中,我们来学习如何使用Angular2来展示数据,以及如何使用它的内置指令NgFor和NgIf首先要确保你有一个可以运行起来的Angular2的样例程
由于angular2兴起不久,相关插件还是很少,所以有时候不得不用一些jquery插件来完成项目,那么如何把jquery插件放到angular2中呢?采用自定义
ChangeDetection(变化检测)是Angular2中最重要的一个特性。当组件中的数据发生变化的时候,Angular2能检测到数据变化并自动刷新视图反映
Augury-Angular专用的chrome调试插件如题,在的2016-12-8谷歌开发者大会上,angular2的leader来给我们演示了angular2