首页前端开发JavaScript一文聊聊Angular中怎么操作DOM元素

一文聊聊Angular中怎么操作DOM元素

时间2024-01-31 04:14:02发布访客分类JavaScript浏览682
导读:收集整理的这篇文章主要介绍了一文聊聊Angular中怎么操作DOM元素,觉得挺不错的,现在分享给大家,也给大家做个参考。Angular中怎么操作DOM元素?下面本篇文章给大家介绍一下angular操作DOM元素的方法,希望对大家有所帮助!在...
收集整理的这篇文章主要介绍了一文聊聊Angular中怎么操作DOM元素,觉得挺不错的,现在分享给大家,也给大家做个参考。Angular中怎么操作DOM元素?下面本篇文章给大家介绍一下angular操作DOM元素的方法,希望对大家有所帮助!

在angular获取DOM元素可以使用javascript的原生API,或者引入jquery通过jquery对象操作DOM,但angular已经给我们提供了相应的API(ElementRef)来获取DOM元素,就没必要使用原生的API或者jQuery了。【相关教程推荐:《angular教程》】

ElementRef 获取DOM元素

1、创建testcomponent组件,模板如下:test.COMponent.htML

div>
    	p>
    你好/p>
    /div>
    div>
        span>
    世界/span>
    /div>
    h1>
    标题/h1>
    pass-badge id="component" textColor="red">
    组件/pass-badge>
    

2、编写test.component.ts文件

import {
 Component, OnInIT }
     From '@angular/core';
// 1、导入 ElementRef 类import {
 ElementRef}
     from '@angular/core';
import {
 PassBadge }
 from './compoment/pass-badge/pass-badge.component'@Component({
  selector: 'app-test',  templateUrl: './test.component.html',  styleUrls: ['./test.component.css'],  declarations: [ PassBadge ]}
)export class TestComponent implements OnInit {
	// 2、将 ElementRef 类注入 test 组件中    constructor(PRivate el:ElementRef) {
}
    ngOnInit() {
    	// 3、获取 DOM 元素        console.LOG(this.el.nativeElement)        console.log(this.el.nativeElement.querySelector('#component'))    }
}
    

我们来看看this.el.nativeElement是什么


所以就可以通过this.el.nativeElement.querySelector('#component')来操作对应的DOM元素。例如改变文字颜色就可以

this.el.nativeElement.querySelector('#component').style.color = 'lightblue'

模板变量获取DOM元素

可以通过@H_7_6@ViewChild获取组件,同样的还有ContentChildViewChildrenContentChildren

1、修改TestComponent组件,为对应元素加上模板变量,如下

div>
        p>
    你好/p>
    /div>
    !-- 1、给元素加入模板变量 div -->
    div #div>
        span>
    世界/span>
    /div>
    h1>
    标题/h1>
    !-- 给组件加入模板变量 component -->
    pass-badge #component textColor="red">
    组件/pass-badge>
    

2、修改test.component.ts,如下:

import {
 Component, OnInit }
     from '@angular/core';
import {
 ElementRef}
     from '@angular/core';
// 2、引入ViewChildimport {
 ViewChild }
 from '@angular/core'@Component({
  selector: 'app-test',  templateUrl: './test.component.html',  styleUrls: ['./test.component.css']}
)export class TestComponent implements OnInit {
    constructor(private el:ElementRef) {
}
        // 3、获取元素    @ViewChild('component') dom: any;
        @ViewChild('div') div: any;
    ngOnInit() {
        console.log(this.dom)	// PassBadgeComponent        this.dom.fn()   // 调用 passbadge 组件的 fn 方法        console.log(this.div)	// ElementRef        this.div.nativeElement.style.color = 'lightblue'	// 文字颜色修改为淡蓝色    }
}
    

最终结果如下

由结果我们可以知道,当使用ViewChild模板变量获取组件元素时,获取到的是组件导出的组件类(上例是PassBadgeComponent),这时候只可以操作组件中含有的属性。

当使用ViewChild模板变量获取html元素时,获取到的时ElementRef类型的类,这时可以通过this.div.nativeElement.querySelector('span')等原生API来操作元素

更多编程相关知识,请访问:编程视频!!

以上就是一文聊聊Angular中怎么操作DOM元素的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: 深入了解React中setState的更新机...下一篇:怎么利用Node.js进行html页面跳转猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员loadpost-format-gallery

若转载请注明出处: 一文聊聊Angular中怎么操作DOM元素
本文地址: https://pptw.com/jishu/593466.html
C语言中%d,%s,%x,%f,%.100的意义 怎么利用Node.js进行html页面跳转

游客 回复需填写必要信息