使用JavaScript模板遇到的错误

在制作一个简单的图片直播网页时,作者遇到了在移动端访问时JavaScript模板不显示的问题。通过尝试和错误定位,发现问题是由于`replaceAll`方法在某些环境中不被支持。通过引入百度的js模板库并修改相关JS方法,成功解决了问题。同时提醒在HTML中引入JS文件时,要避免缓存问题,可使用时间戳参数。

最近做了一个简易的图片直播网页,就一个html页面,所以就懒得搞vue什么的,想着直接一个JavaScript就差不多OK了。万万没想到差点栽在这个纯JavaScript上了。

遇到的问题

模板

<script id="J_picTpl" type="template">
    <li class="col-md-3 post">
        <figure>
            <img src="url" data-id="{id}">
            <figcaption>
                <h3>{title}</h3>
                <span>{datetime}</span>
            </figcaption>
        </figure>
    </li>
</script>

js语句

...
let template = $("#J_picTpl").html();
let html = template.replaceAll('url', item.coverUrl);
...

好,那么问题来了,正常情况下,在pc端,无论是哪个浏览器,都是没有任何问题的。

但是,谁能告诉我为什么移动端访问,甚至就是pc端的微信访问都会不显示模板呢??

最让人头痛的还是没想到问题出在哪里了,这里我是找到了错误是replaceAll导致的,当你不知道的情况下,移动端都没有控制台,也不知道错误在哪里。

还好我的Java经验告诉了我,try catch是个好东西,JavaScript也有

加上

try {
	...
	let template = $("#J_picTpl").html();
	let html = template.replaceAll('url', item.coverUrl);
	...
}catch(err) {
	// 我用的layui,如果没有的话可以直接把结果通过$("id").html输出到页面上
	layer.msg(err.message)
}

移动端运行后显示错误是template.replaceAll不是一个方法

行吧,原生模板的问题,那我换个js模板呗

搜了一下用了百度js模板完美解决,这里记录一下解决方法

引入js包

<script type="text/javascript" src="js/baiduTemplate.js"></script>

编写模板文件

<script id="J_picTpl" type="text/template">
    <li class="col-md-3 post">
        <figure>
            <img lay-src="<%=src%>" data-id="<%=id%>">
            <figcaption>
                <h3><%=title%></h3>
                <span><%=datatime%></span>
            </figcaption>
        </figure>
    </li>
</script>

其他用法可以参考他的文档,我这里只是简单的替换,就没搞那些花里胡哨的了

改写js方法

// 使用百度模板
let bt = baidu.template;
// 模板中的数据
let date = {
	src: "",
	id: 0,
	title: "",
	datatime: ""
}
...
date.src = "https://xxxx/xxx.png";
date.id = 11;
title = "title";
datetime = "2021年1月5日";
...
let outHtml = baidu.template('J_picTpl', date);
// outHtml就是渲染出来的页面代码
$("#id").html(outHtml);
...

好了,这里就可以了,顺便记一下,html中引入js一定要用script引用js文件,而不是直接写在script标签下,否则会出现线上代码更新不即时,通过在引入的src后面加一个?v=20210105等其他时间戳,做到避免使用缓存数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值