时间:2021-05-25
在使用Angular2+中,经常会想快速的去选择DOM上的某个元素,如果是刚上手Angular,有可能直接就使用原生DOM操作或者导入jQuery再进行DOM操作,既然都使用了Angular了,有没有更好的方法呢?答案是肯定的。
通过ElementRef
先上代码:
import {Component, ElementRef, OnInit} from '@angular/core';@Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css']})export class AppComponent implements OnInit{ color:string; title = 'button !'; constructor(private el:ElementRef){} setHeight(){ this.el.nativeElement.querySelector('.btn1').style.height = '300px'; } ngOnInit(){ this.setHeight(); }}<h1> {{title}}</h1><div><button myHighlight class="btn btn1">按钮一</button><button myHighlight class="btn">按钮二</button><button myHighlight class="btn">按钮三</button></div>效果是这样:
上述代码中的nativeElement其实包含的是组件中所有的DOM元素,如下图所示:
通过调用querySelectorAPI就能获取页面元素,需要注意的是querySelector只返回第一个元素,当你需要选择多个元素的时候可以使用querySelectorAll。
通过@viewChild
<h1> {{title}}</h1><div><button myHighlight class="btn btn1">按钮一</button><button myHighlight class="btn" #btn>按钮二</button> <!--增加一个变量--><button myHighlight class="btn">按钮三</button></div>import {Component, ElementRef, OnInit, ViewChild} from '@angular/core';@Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css']})export class AppComponent implements OnInit{ @ViewChild('btn') btn:ElementRef;//通过@ViewChild获取元素 color:string; title = 'button !'; constructor(private el:ElementRef){} setHeight(){ this.el.nativeElement.querySelector('.btn1').style.height = '300px'; } setWidth(){ this.btn.nativeElement.style.width = '200px';//定义宽度 } ngOnInit(){ this.setHeight(); this.setWidth(); }}效果如下:
如果多个HTML元素都定义了相同的变量,使用@viewChild时只能选择到第一个元素。
更好的方法是配合renderer2对象提供的API去实现同样的效果,这样减少应用层与渲染层之间强耦合关系:
import {Component, ElementRef, OnInit, Renderer2, ViewChild} from '@angular/core';@Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css']})export class AppComponent implements OnInit{ @ViewChild('btn') btn:ElementRef; color:string; title = 'button !'; //初始化renderer2 constructor(private el:ElementRef,private renderer2: Renderer2){} setHeight(){ this.el.nativeElement.querySelector('.btn1').style.height = '300px'; } setWidth(){ // this.btn.nativeElement.style.width = '200px'; //使用renderer2的setStyle方法设置宽度 this.renderer2.setStyle(this.btn.nativeElement,'width','200px') } ngOnInit(){ this.setHeight(); this.setWidth(); }}参考文章中都提到了@viewChild配合renderer选择元素,但是在Angular4中renderer已经废弃掉了,变成了renderer2。
renderer2API中还有其他的一些方法可以用来进行一些DOM操作:
class Renderer2 { data : {[key: string]: any} destroy() : void createElement(name: string, namespace?: string) : any createComment(value: string) : any createText(value: string) : any destroyNode : (node: any) => void | appendChild(parent: any, newChild: any) : void insertBefore(parent: any, newChild: any, refChild: any) : void removeChild(parent: any, oldChild: any) : void selectRootElement(selectorOrNode: string|any) : any parentNode(node: any) : any nextSibling(node: any) : any setAttribute(el: any, name: string, value: string, namespace?: string) : void removeAttribute(el: any, name: string, namespace?: string) : void addClass(el: any, name: string) : void removeClass(el: any, name: string) : void setStyle(el: any, style: string, value: any, flags?: RendererStyleFlags2) : void removeStyle(el: any, style: string, flags?: RendererStyleFlags2) : void setProperty(el: any, name: string, value: any) : void setValue(node: any, value: string) : void listen(target: 'window'|'document'|'body'|any, eventName: string, callback: (event: any) => boolean | void) : () => void}以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在前面Angularjs开发一些经验总结中我们说到在angular开发中angularcontrollernever包含DOM元素(html/css),在con
结构指令是什么?结构指令通过添加和删除DOM元素来更改DOM布局。Angular中两个常见的结构指令是*ngIf和*ngFor。了解*号语法*号是语法糖,用于避
在Angular中,我们不应该试图直接修改DOM的内容,当需要更新DOM内容的时候,应该修改的其实是我们的数据模型,也就是$scope中的数据,Angular会
本文实例讲述了javascript动态创建及删除元素的方法。分享给大家供大家参考。具体分析如下:在DOM中我们可以方便快速的动态删除与删除dom元素,这里我们就
本文介绍了详解angularjs获取元素以及angular.element()用法,分享给大家,具体如下:addClass()-为每个匹配的元素添加指定的样式类