微信小程序 wxParse插件显示视频问题
修改wxParse/html2json.js 文件 ,在 html2json(html, bindName)
方法里
var node = { node: 'element', tag: tag, };
这里使用 node.tag 能够获取标签类型,比如: img、embed、video
这里我的系统后台编辑器使用的是ckeditor 上传视频。生成的便签是:embed
所以加上判断:
if (node.tag =="embed"){ var embUrl = node.attr.src; if (node.attr.src.indexOf('http:')==-1){ embUrl = "http://xxxx.com" + node.attr.src; } node.attr.src = embUrl; node.tag='video'; }
插件里只判断了video标签,识别不出来embed 标签,所有视频无法显示,加上判断,这样就可以了。
知识点扩展:微信小程序插件wxParse的使用
由于微信小程序不支持后台富文本编辑器编辑的html,需要使用wxParse 这个插件来解析,下面介绍一下这个插件的使用方法。
1.下载插件
在GigHub上面找到插件Demo,地址为 https://github.com/icindy/wxParse,把Demo里面的wxParse目录拷贝到项目里面.
2.在当前页面的JS里引入wxParse.js
var WxParse = require('../../wxParse/wxParse.js'); Page({ data: {}, onLoad: function() { var that = this; // 映射表情包 WxParse.emojisInit('[]', "/wxParse/emojis/", { "00": "00.gif", "01": "01.gif", "02": "02.gif", "03": "03.gif", "04": "04.gif", "05": "05.gif", "06": "06.gif", "07": "07.gif", "08": "08.gif", "09": "09.gif", "09": "09.gif", "10": "10.gif", "11": "11.gif", "12": "12.gif", "13": "13.gif", "14": "14.gif", "15": "15.gif", "16": "16.gif", "17": "17.gif", "18": "18.gif", "19": "19.gif", }); var article = `<div>从后端获取的HTML格式文件</div>`; WxParse.wxParse('article', 'html', article, that, 5); // WxParse.wxParse(bindName, type, data, target, imagePadding); // bindName绑定的数据名(必填) // type可以为html或者md(必填) // data为传入的具体数据(必填) // target为Page对象, 一般为this(必填) // imagePadding为当图片自适应是左右的单一padding(默认为0, 可选) } })
3.在全局app.wxss引入wxParse.wxss
@import "wxParse/wxParse.wxss";
4.在当前页面wxml中引入wxParse.wxml
<import src="../../wxParse/wxParse.wxml"/> <view class="wxParse"> <!-- 这里data中article为bindName --> <template is="wxParse" data="{{wxParseData:article.nodes}}"/> </view>
总结
以上所述是小编给大家介绍的微信小程序 wxParse插件显示视频问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
相关文章
JavaScript的模块化:封装(闭包),继承(原型) 介绍
在复杂的逻辑下, JavaScript 需要被模块化,模块需要封装起来,只留下供外界调用的接口。闭包是 JavaScript 中实现模块封装的关键,也是很多初学者难以理解的要点2013-07-07
最新评论