动态创建dom元素

一、动态创建dom元素

   //创建input标签
   var ipt = document.createElement("input");
   //设置type属性
   ipt.type = "button";
   //设置值
   ipt.value = "按钮";
   console.log(ipt);

在这里插入图片描述

二、将创建的元素动态追加到页面元素

1. appendChild()------子元素追加方法

  • 追加到当前元素的内容之后

2. 向body里面追加

document.body.appendChild(ipt);

3. 向任意标签追加元素

  • insertBefore()----将新的节点插入已有的节点之前
  • insertBefore()只有这一个方法
  • document.body.insertBefore(要插入的元素,已有的元素);
<input type="text" id="user"/>
<script>
	document.body.insertBefore(ipt,user);
</script>

在这里插入图片描述

  • insertAfter()—这个方法不存在,原生js不存在

三、实现insertAfter()方法的功能(插入到一个节点之后)

  • 一般想法就是插入到下一个节点之前
Node.prototype.insertAfter = function(newchild,refchild){    
     this.insertBefore(newchild,refchild.nextElementSibling);
     //指的是当前的类对象
}
document.body.insertAfter(ipt,user);

在这里插入图片描述

四、移除

1.移除dom元素

	ipt.remove();

2.删除dom元素子集

   var ulmenu=document.querySelector("ul");
   console.log(ulmenu.children);//HTMLCollection [li]
   var firstli=ulmenu.children[0];
   ulmenu.removeChild(firstli);

五、创建字符串标签

   var s="<input type='text' value='123'/>";
   document.body.innerHTML+=s;
   console.log(document.body.innerHTML);//元素+标签+代码
   console.log(document.body.innerText);//只输出文本
  • innerHTML和innerText的区别见https://editor.csdn.net/md/?articleId=111051945
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
在Vue中,可以使用createElement函数动态创建DOM元素。createElement函数接受三个参数,分别是标签名、属性对象和子元素。通过调用createElement函数,可以创建一个虚拟节点(vnode),然后将其插入到父元素中。 例如,如果要创建一个div标签,并给其添加子元素,可以使用以下代码: ```javascript render(createElement) { return createElement('div', {}, \[ createElement('p', {}, '这是一个段落'), createElement('span', {}, '这是一个span元素') \]) } ``` 在上述代码中,createElement('div', {}, \[...\])创建了一个div标签,并使用第三个参数添加了两个子元素p和span。 另外,如果想要创建组件节点,可以使用createComponent函数。在Vue的组件系统中,子组件的初始化创建是在createElm函数中进行的。 总结起来,Vue动态创建DOM元素可以通过createElement函数来实现,同时也可以使用createComponent函数来创建组件节点。 #### 引用[.reference_title] - *1* *3* [Vue.js源码解析-Vue初始化流程之动态创建DOM](https://blog.csdn.net/weixin_57699483/article/details/118994933)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Vue2笔记_01创建vdom并挂载到dom元素上](https://blog.csdn.net/qq_43260366/article/details/126908076)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南初️

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值