我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue中原生template标签失效怎么解决

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue中原生template标签失效怎么解决

这篇“Vue中原生template标签失效怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue中原生template标签失效怎么解决”文章吧。

一、事件未绑定的原因

找了整一天也没找着这事件为什么触发不了, 在这中间还把代码简化掉只留下事件触发逻辑执行了好几次.

第二天意识到原生代码里的template可能有问题, 在原生环境中template标签内部的东西是不会渲染出来的, 虽然解析器在加载页面的时候确实会处理这部分代码片段.

取自MDN:

将模板视为一个可存储在文档中以便后续使用的内容片段. 
虽然解析器在加载页面时确实会处理 <template> 元素的内容,
但这样做只是为了确保这些内容有效, 元素内容不会被渲染.

但是放到vue里(这里特指Vue2), 如果template标签在Vue实例绑定的元素内部存在(即不是根元素外的那个template), 那么在DOM中该template的子元素是正常存在并显示的, 我以前经常拿templatev-for容器.

然后联想前面几次结构简化demo, 大概不是没绑定而是绑错了目标.

这个原生项目的HTML代码很多, 所以作者做了一些优化, 在需要某个模块的时候才将其appendChild加入DOM, 其余的时候这些模块都被放在template标签内, 而vue把这些东西都出来渲染了, 那么初始化的时候事件大概率就已经被绑到了template里面的那些代码里, 等到这些模块被appendChild的时候, 事件绑定已经结束了, 所以appendChild是将没有事件绑定的DOM加到了正确位置.

我在控制台把视口里的DOM都删掉之后发现下面还有一层被挤出去的DOM, 那是有事件绑定的DOM.

的确是这样.

二、如何处理原生template标签

我是想把他appendChild这个优化留下来的, 我觉得在原生环境里能有这种封装的思想挺好, 不过看起来不好办&hellip;

我打算把原来那几个模块抽到组件里, 提前把组件写到后面会插入到的位置, 然后用这种结构控制显示隐藏:

<template v-if="isShow">  <aaa></aaa></template>

这样挺好的其实, 如果这个项目的结构再简单一点我绝对会用组件方案的, 结果我发现我要传回调函数, 传4层干扰到3个很重要的类, 只是为了在合适的时机回调改变组件的状态, 我觉得很糟糕.

而且, 如果后面会有&hellip;或者现在就有我没有察觉到的需求是增加不定数量个这种模块, 我把组件直接注册到这里用就算是写死了, 恐怕会不好改.

需要这种操作的组件有三个, 我想起来学后端渲染的时候给前端发的html模板, 那&hellip;能不能把这些html转成字符串存到一个单独的js文件, 然后在需要的地方导入后appendChild呢? 这样对源代码改动最小, 不用改appendChild, 也让html文档那边更简洁一些.

export const batchEditorToolsTemplate = `  <div id="batch-editor-tools-wrapper" class="non-selectable"><div id="batch-editor-tools">  <div class="menu-button" id="exit">退出</div>  <div class="menu-button" id="prev">上一页</div>  <div class="menu-button" id="next">下一页</div>  <div class="menu-button" id="trajectory">轨迹</div>  <div class="menu-button" id="auto-annotate">自动</div>  <div class="menu-button" id="auto-annotate-translate-only">自动(无旋转)</div>  <div class="menu-button" id="interpolate">插值</div>  <div class="menu-button" id="reload">重新加载</div>  <div class="menu-button" id="finalize">定稿</div></div>  </div>`

然后用这个工具函数把appendChild替换掉:

function analyseDomStr(str, target) { // dom字符串, 目标元素  const template = document.createElement('template');  template.innerHTML = str;  target.appendChild(template.content);}

这样性能不如之前好, 不过&mdash;&mdash;事件绑定看起来没什么问题了.

本来想用Document.createDocumentFragment()API的, 所以初版就写成这样了:

function analyseDomStr(str, target) { // dom字符串, 目标元素  const fragment = document.createDocumentFragment();  const template = document.createElement('template');  template.innerHTML = str;  fragment.appendChild(template.content); // 此处还是要按照原生template的那套来的, 这个template不会被vue特殊解析  target.appendChild(fragment);}

很遗憾并不能直接使用innerHTMLDocumentFragment内写入DOM, 仍旧需要appendChild来完成, 所以完全没有必要创建DocumentFragment, 我认为这个API更加适合用于对频繁DOM操作进行优化, 比如用户点击按钮后就要插入100条tips, 那就更适合先使用这个API生成一个文档内容分段, 然后把成品分段加入DOM.

这个初版和旧版也都是回流一次&hellip;

因为文档片段存在于内存中, 并不在 DOM 树中, 所以将子元素插入到文档片段时不会引起页面回流(对元素位置和几何上的计算).
因此, 使用文档片段通常会带来更好的性能.

完全可以把:

const ul = document.querySelector('ul');const li = document.createElement('li');for (let i = 0; i < 100; i++) {  ul.appendChild('li');}

这种会引起页面频繁回流的写法

改成

const ul = document.querySelector('ul');const li = document.createElement('li');const fragment = document.createDocumentFragment();for (let i = 0; i < 100; i++) {  fragment.appendChild('li');}ul.appendChild(fragment);

这样页面只会在fragmentappendChild后回流一次.

以上就是关于“Vue中原生template标签失效怎么解决”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue中原生template标签失效怎么解决

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue中原生template标签失效怎么解决

这篇“Vue中原生template标签失效怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue中原生template
2023-07-05

Vue中原生template标签失效如何解决

这篇文章主要介绍了Vue中原生template标签失效如何解决,找了整一天也没找着这事件为什么触发不了,第二天意识到原生代码里的template可能有问题,在原生环境中template标签内部的东西是不会渲染出来的,虽然解析器在加载页面的时候确实会处理这部分代码片段
2023-02-22

input标签οnpaste不生效怎么解决

当使用``标签时,`onpaste`事件应该是生效的。如果它没有生效,可能有几种可能的原因和解决方法:1. 检查是否正确绑定了`onpaste`事件。确保在``标签中添加了正确的`onpaste`属性,例如:``。2. 确保`onpaste
2023-08-20

vue中template报错问题怎么解决

这篇文章主要讲解了“vue中template报错问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue中template报错问题怎么解决”吧!template报错写这个纯粹是为了纪
2023-06-30

vue在mounted中window.onresize不生效怎么解决

这篇文章主要介绍“vue在mounted中window.onresize不生效怎么解决”,在日常操作中,相信很多人在vue在mounted中window.onresize不生效怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作
2023-06-30

HTML中input type="reset"标签失效的原因是什么

小编给大家分享一下HTML中input type="reset"标签失效的原因是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!使用标签
2023-06-08

Vue设置keepAlive不生效怎么解决

本篇内容主要讲解“Vue设置keepAlive不生效怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue设置keepAlive不生效怎么解决”吧!设置keepAlive不生效如演示,Vu
2023-06-30

android生成签名证书无效怎么解决

如果你的Android生成签名证书无效,可以尝试以下解决办法:1. 确保你使用的是正确的密钥库文件(.keystore)和别名(alias)。检查密钥库文件的路径和别名是否正确,并确保你正在使用正确的证书进行签名。2. 检查密钥库密码和密钥
2023-10-19

vue-cli3+webpack热更新失效怎么解决

这篇文章主要讲解了“vue-cli3+webpack热更新失效怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue-cli3+webpack热更新失效怎么解决”吧!vue-cli3+
2023-06-30

ASP.net中Attributes.Add()失效怎么解决

ASP.NET中使用Attributes.Add()方法添加属性时,如果失效,可以尝试以下解决方法:1. 确保在正确的事件中添加属性。确保在正确的事件中执行Attributes.Add()方法,例如在Page_Load事件中添加属性,而不是
2023-08-08

vue注释template中组件的属性报错怎么解决

这篇文章主要讲解了“vue注释template中组件的属性报错怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue注释template中组件的属性报错怎么解决”吧!注释templat
2023-06-30

vue热替换失效的原因是什么及如何解决

今天小编给大家分享一下vue热替换失效的原因是什么及如何解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.观察文件位置错
2023-07-04

vue组件添加样式不生效怎么解决

本文小编为大家详细介绍“vue组件添加样式不生效怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue组件添加样式不生效怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。具体场景如下//// vue
2023-07-04

vue template中style背景设置不编译问题怎么解决

这篇文章主要介绍了vue template中style背景设置不编译问题怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue template中style背景设置不编译问题怎么解决文章都会有所收获,下面
2023-06-30

怎么解决css中overflow:hidden失效的问题

这篇文章给大家分享的是有关怎么解决css中overflow:hidden失效的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。失效原因今天在写轮播图的时候发现,overflow;hidden;竟然能失效,发现原
2023-06-08

vue中@click绑定事件点击不生效的原因及解决方案

根据Vue2.0官方文档关于父子组件通讯的原则,父组件通过prop传递数据给子组件,子组件触发事件给父组件,这篇文章主要介绍了vue中@click绑定事件点击不生效的解决方案,需要的朋友可以参考下
2022-12-08

Vue组件更新数据v-model不生效怎么解决

今天小编给大家分享一下Vue组件更新数据v-model不生效怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。组件更新数
2023-06-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录