利用微信开放标签<wx-open-launch-weapp>在H5中跳转微信小程序报错完美的解决方案

一、报错:

[WXTAG] [JSCORE] The slot <template> or <script type="text/wxtag-template"> of <wx-open-launch-weapp> is missing

二、源码

官方源代码如下,<script type="text/wxtag-template"></script > 这段代码,网上也有用 template 标签的。

javascript 复制代码
<wx-open-launch-weapp
  id="launch-btn"
  appid="wx12345678"
  path="pages/home/index?user=123&action=abc"
>
  <script type="text/wxtag-template">
    <style>.btn { padding: 12px }</style>
    <button class="btn">打开小程序</button>
  </script>
</wx-open-launch-weapp>
<script>
  var btn = document.getElementById('launch-btn');
  btn.addEventListener('launch', function (e) {
    console.log('success');
  });
  btn.addEventListener('error', function (e) {
    console.log('fail', e.detail);
  });
</script>

当我直接在Vue3中用上边代码运行会报错:

[Vue warn]: Template compilation error: Tags with side effect (<script> and <style>) are ignored in client component templates.

报错原因:

这个报错信息通常出现在使用客户端渲染的前端框架中,当你在组件中使用了<script><style>标签,并且这些标签带有副作用时。

报错解释:

在客户端渲染的前端框架中,组件通常被视为无副作用的函数,这意味着组件的渲染不应该有任何副作用,例如修改全局状态或外部资源。<script><style>标签如果用于注入JavaScript或CSS,可能会导致副作用。

三、解决思路

其实官方给的代码样例,我们是不能直接用在Vue中的,往往这样的 template标签直接给编译没有了。

所以我们考虑用动态生成组件的办法来,生成标签,就可以解决这个问题了,到目前为止,这是我找到的最好的解决方案。

替换:

javascript 复制代码
<script>
  // JS CODE HERE
</script>

通过以下方式:

javascript 复制代码
<component :is="'script'">
  // JS Here
</component>

这里我试了 templatescript 这两个标签动态生成,此时会报如下错误:

[WXTAG] [JSCORE] The slot <template> or <script type="text/wxtag-template"> of <wx-open-launch-weapp> is missing

是因为 script 标签还有个 type="text/wxtag-template" 属性导致的,如果我们将这个type属性也动态生成好,不就可以解决问题了。

javascript 复制代码
<wx-open-launch-weapp
	id="launch-btn"
	appid=""
    path="pages/index/index"
>
	<component :is="'script'" v-bind="{type:'text/wxtag-template'}">
		  <div>测试打开小程序</div>
	</component>
</wx-open-launch-weapp>

果然完美解决问题~~~ 亲测亲测~~~~ 坑哭了~~~~

四、总结

主要有两个原因导致,第一个Vue 中的 template 标签和微信官方要求template标签不是一个东西。第二个Vue中 script 标签 不能随便在视图部分插入并破坏属性。基于以上问题我们可以通过动态生成组件标签的方案来解决。

组件(Component)是 Vue.js 最强大的功能之一。组件可以扩展 HTML 元素,封装可重用的代码。在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊功能。在有些情况下,组件也可以是原生 HTML 元素的形式,以 is 特性扩展。

相关推荐
css趣多多3 分钟前
案例自定义tabBar
前端
风与沙的较量丶25 分钟前
Java中的局部变量和成员变量在内存中的位置
java·开发语言
m0_7482517226 分钟前
SpringBoot3 升级介绍
java
林的快手1 小时前
CSS列表属性
前端·javascript·css·ajax·firefox·html5·safari
极客先躯2 小时前
说说高级java每日一道面试题-2025年2月13日-数据库篇-请说说 MySQL 数据库的锁 ?
java·数据库·mysql·数据库的锁·模式分·粒度分·属性分
程序员侠客行2 小时前
Spring事务原理 二
java·后端·spring
匹马夕阳2 小时前
ECharts极简入门
前端·信息可视化·echarts
bug总结2 小时前
新学一个JavaScript 的 classList API
开发语言·javascript·ecmascript
小猫猫猫◍˃ᵕ˂◍2 小时前
备忘录模式:快速恢复原始数据
android·java·备忘录模式
liuyuzhongcc2 小时前
List 接口中的 sort 和 forEach 方法
java·数据结构·python·list