前端原生和主流框架是如何dom的

2023-09-21 09:14:43

前言

随着互联网技术的发展,前端技术也在不断地发展和更新。DOM(Document Object Model)是前端开发中非常重要的一个概念,可以理解为网页上的所有元素都是DOM节点,通过操作这些节点,可以实现网页的动态效果交互功能。本文将介绍JavaScript操作DOM、jQuery操作DOM、Vue操作DOM、React操作DOM、Uniapp操作DOM的区别。

一、JavaScript操作DOM

JavaScript是前端开发中最基础的语言,也是操作DOM最原始的方式。通过JavaScript可以获取和修改DOM节点的属性和内容,实现网页的动态效果交互功能。JavaScript操作DOM的主要方法有以下几种:

  1. document.getElementById():通过元素的id属性获取DOM节点。

  2. document.getElementsByTagName():通过元素的标签名获取DOM节点。

  3. document.getElementsByClassName():通过元素的class属性获取DOM节点。

  4. document.createElement():创建一个新的DOM节点。

  5. element.appendChild():将一个DOM节点添加到另一个DOM节点的子节点列表中。

  6. element.removeChild():从一个DOM节点的子节点列表中删除一个子节点。

// 选择元素并修改内容
document.getElementById("myElement").innerHTML = "Hello, JavaScript!";

// 创建新元素并添加到文档中
var newElement = document.createElement("div");
newElement.textContent = "This is a new element";
document.body.appendChild(newElement);

// 添加事件监听器
document.getElementById("myButton").addEventListener("click", function() {
  alert("Button clicked!");
});

二、jQuery操作DOM

jQuery是一个非常流行的JavaScript库,它封装了许多常用的DOM操作方法,使得操作DOM更加简单方便。jQuery操作DOM的主要方法有以下几种:

  1. $(selector):通过选择器获取DOM节点。

  2. $(selector).html():获取或设置DOM节点的HTML内容。

  3. $(selector).text():获取或设置DOM节点的文本内容。

  4. $(selector).attr():获取或设置DOM节点的属性值。

  5. $(selector).addClass():给DOM节点添加一个或多个类。

  6. $(selector).removeClass():从DOM节点中删除一个或多个类。

// 选择元素并修改内容
$("#myElement").html("Hello, jQuery!");

// 创建新元素并添加到文档中
var newElement = $("<div>").text("This is a new element");
$("body").append(newElement);

// 添加事件监听器
$("#myButton").on("click", function() {
  alert("Button clicked!");
});

三、Vue操作DOM

Vue是一种流行的JavaScript框架,它提供了一种声明式的方式来操作DOM。Vue操作DOM的主要方式是通过模板语法来描述DOM结构和数据绑定关系。Vue的模板语法类似于HTML,但是可以包含JavaScript表达式和指令,可以实现动态的DOM操作。Vue操作DOM的主要方式有以下几种:

  1. {{ expression }}:在DOM中插入JavaScript表达式的结果。

  2. v-bind:attribute=“expression”:动态地绑定DOM节点的属性值。

  3. v-if=“expression”:根据表达式的值来插入或移除DOM节点。

  4. v-for=“item in list”:根据列表数据生成DOM节点。

  5. v-on:event=“handler”:绑定DOM事件处理函数。

<template>
  <div>
    <p>{{ message }}</p>
    <button @click="handleClick">Click me</button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      message: "Hello, Vue!"
    };
  },
  methods: {
    handleClick() {
      alert("Button clicked!");
    }
  }
};
</script>

四、React操作DOM

React是另一种流行的JavaScript框架,它提供了一种组件化的方式来操作DOM。React将DOM视为一组组件,每个组件都有自己的状态和属性,可以通过组合嵌套来构建复杂的DOM结构。React操作DOM的主要方式是通过JSX语法来描述DOM结构和数据绑定关系。JSX语法类似于HTML,但是可以包含JavaScript表达式和组件,可以实现动态的DOM操作。React操作DOM的主要方式有以下几种:

  1. {expression}:在DOM中插入JavaScript表达式的结果。

  2. Component attribute={expression} :动态地绑定DOM节点的属性值。

  3. {condition ? trueNode : falseNode}:根据条件来插入或移除DOM节点。

  4. {list.map(item => <Component key={item.id} {…item} />)}:根据列表数据生成DOM节点。

  5. Component onClick={handler} :绑定DOM事件处理函数。

jsx
import React from "react";

class MyComponent extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      message: "Hello, React!"
    };
  }

  handleClick() {
    alert("Button clicked!");
  }

  render() {
    return (
      <div>
        <p>{this.state.message}</p>
        <button onClick={this.handleClick}>Click me</button>
      </div>
    );
  }
}

export default MyComponent;

五、Uniapp操作DOM

Uniapp是一种跨平台的移动应用开发框架,它支持多种前端框架,包括Vue和React。Uniapp操作DOM的方式与Vue和React类似,主要是通过模板或JSX语法来描述DOM结构和数据绑定关系。Uniapp操作DOM的主要方式有以下几种:

  1. {{ expression }}:在DOM中插入JavaScript表达式的结果。

  2. :attribute=“expression”:动态地绑定DOM节点的属性值。

  3. v-if=“expression”:根据表达式的值来插入或移除DOM节点。

  4. v-for=“item in list”:根据列表数据生成DOM节点。

  5. @event=“handler”:绑定DOM事件处理函数。

<template>
  <view>
    <text>{{ message }}</text>
    <button @click="handleClick">Click me</button>
  </view>
</template>

<script>
export default {
  data() {
    return {
      message: "Hello, Uniapp!"
    };
  },
  methods: {
    handleClick() {
      uni.showToast({
        title: "Button clicked!",
        icon: "none"
      });
    }
  }
};
</script>

总结

以上就是JavaScript操作DOM、jQuery操作DOM、Vue操作DOM、React操作DOM、Uniapp操作DOM的区别。JavaScript是最原始的操作DOM的方式,
jQuery封装了常用的DOM操作方法,
Vue和React提供了声明式和组件化的方式来操作DOM,
Uniapp支持多种前端框架,可以快速开发跨平台的移动应用,
不同的操作DOM方式有各自的优缺点。

更多推荐

基于FPGA的图像sobel锐化实现,包括tb测试文件和MATLAB辅助验证

目录1.算法运行效果图预览2.算法运行软件版本3.部分核心程序4.算法理论概述5.算法完整程序工程1.算法运行效果图预览将FPGA的仿真结果导入到matlab显示图像效果2.算法运行软件版本MATLAB2022a,vivado2019.23.部分核心程序.................................

【洛谷 P1364】医院设置 题解(图论+深度优先搜索)

医院设置题目描述设有一棵二叉树,如图:其中,圈中的数字表示结点中居民的人口。圈边上数字表示结点编号,现在要求在某个结点上建立一个医院,使所有居民所走的路程之和为最小,同时约定,相邻接点之间的距离为111。如上图中,若医院建在111处,则距离和=4+12+2×20+2×40=136=4+12+2\times20+2\ti

分布式调度 Elastic-job

分布式调度Elastic-job1.概述1.1什么是任务调度我们可以思考一下下面业务场景的解决方案:某电商平台需要每天上午10点,下午3点,晚上8点发放一批优惠券某银行系统需要在信用卡到期还款日的前三天进行短信提醒某财务系统需要在每天凌晨0:10分结算前一天的财务数据,统计汇总以上场景就是任务调度所需要解决的问题任务调

“混合”引擎为通用子模块提供动力,实现嵌入式I / O灵活性

现成的组件对于嵌入式开发工程师而言并不是什么新鲜事物。但是,实际上没有人期望一种“一刀切”的解决方案,尤其是在涉及复杂的I/O要求的情况下。但是,基于流行的夹层卡格式的具有成本效益的现场可编程门阵列(FPGA)技术的新实现正在“针对VME,PCI,CompactPCI和VME提供可承受的标准硬件和自由形式的I/O多功能

Mac FoneLab for Mac:轻松恢复iOS数据,专业工具助力生活

如果你曾经不小心删除了重要的iOS数据,或者因为各种原因丢失了这些数据,那么你一定知道这种痛苦。现在,有一个名为MacFoneLab的Mac应用程序,它专门设计用于恢复iOS数据,这可能是你的救星。MacFoneLabforMac是一种强大的工具,它可以帮助你恢复各种类型的iOS数据,包括照片、视频、联系人、短信、通话

Vulnhub实战-DC9

前言本次的实验靶场是Vulnhub上面的DC-9,其中的渗透测试过程比较多,最终的目的是要找到其中的flag。一、信息收集对目标网络进行扫描arp-scan-l对目标进行端口扫描nmap-sC-sV-oAdc-9192.168.1.131扫描出目标开放了22和80两个端口,访问目标的80端口。对目标进行目录扫描与分析。

大数据课程M2——ELK的ELASTICSEARCH概述

文章作者邮箱:yugongshiye@sina.cn地址:广东惠州▲本章节目的⚪了解ELK的ELASTICSEARCH概括;⚪掌握ELK的ELASTICSEARCH核心概念;一、ELASTICSEARCH概括1.ES安装和启动注意:如果使用达内云主机,无需安装es,直接配置yml启动即可。1.安装下载ES最新版本的安装

iOS xcframework项目提示“ld: framework not found”

iOSxcframework项目提示“ld:frameworknotfound”问题描述公司有一个项目,同时引用了.framework和.xcframework,但是使用xcode编译的时候,xcodebuildarchive-project${project_Name}.xcodeproj-target${targe

FreeRTOS移植以及核心功能

文章目录freertos和ucos区别,优缺点比较移植步骤核心功能内存管理(5种内存管理策略)FreeRTOS任务调度算法有三种时间管理通信管理栈管理freertos和ucos区别,优缺点比较FreeRTOS(FreeReal-TimeOperatingSystem)和uC/OS(Micro-controllerOpe

使用Leaflet对WMS做空间几何范围查询

一、需求使用GeoServer发布的WMS服务对WMS做空间范围查询,默认情况下WMS支持点击查询,网上有很多的资料不在赘述。那么WMS做几何查询该怎么实现呢?二、实现路径查询WMS查询的服务参数,WMS支持三种请求方式:GetCapabilities、GetMap、GetFeatureInfo。其中GetCapabi

Transaction - 记一次 Spring 事务联合 Redis 挂了引发的生产事故

问题描述java.lang.RuntimeException:java.lang.IllegalStateException:Alreadyvalue[…数据源信息…]boundtothread[[Ljava.lang.String;@231b1ae0.container-0-C-1]上述问题是本次问题的最终结果,但并

热文推荐