160 lines
4.6 KiB
JavaScript
160 lines
4.6 KiB
JavaScript
|
/**
|
|||
|
* author: Di (微信小程序开发工程师)
|
|||
|
* organization: WeAppDev(微信小程序开发论坛)(http://weappdev.com)
|
|||
|
* 垂直微信小程序开发交流社区
|
|||
|
*
|
|||
|
* github地址: https://github.com/icindy/wxParse
|
|||
|
*
|
|||
|
* for: 微信小程序富文本解析
|
|||
|
* detail : http://weappdev.com/t/wxparse-alpha0-1-html-markdown/184
|
|||
|
*/
|
|||
|
|
|||
|
/**
|
|||
|
* utils函数引入
|
|||
|
**/
|
|||
|
import showdown from './showdown.js';
|
|||
|
import HtmlToJson from './html2json.js';
|
|||
|
/**
|
|||
|
* 配置及公有属性
|
|||
|
**/
|
|||
|
var realWindowWidth = 0;
|
|||
|
var realWindowHeight = 0;
|
|||
|
wx.getSystemInfo({
|
|||
|
success: function (res) {
|
|||
|
realWindowWidth = res.windowWidth
|
|||
|
realWindowHeight = res.windowHeight
|
|||
|
}
|
|||
|
})
|
|||
|
/**
|
|||
|
* 主函数入口区
|
|||
|
**/
|
|||
|
function wxParse(bindName = 'wxParseData', type='html', data='<div class="color:red;">数据不能为空</div>', target,imagePadding) {
|
|||
|
var that = target;
|
|||
|
var transData = {};//存放转化后的数据
|
|||
|
if (type == 'html') {
|
|||
|
transData = HtmlToJson.html2json(data, bindName);
|
|||
|
console.log(JSON.stringify(transData, ' ', ' '));
|
|||
|
} else if (type == 'md' || type == 'markdown') {
|
|||
|
var converter = new showdown.Converter();
|
|||
|
var html = converter.makeHtml(data);
|
|||
|
transData = HtmlToJson.html2json(html, bindName);
|
|||
|
console.log(JSON.stringify(transData, ' ', ' '));
|
|||
|
}
|
|||
|
transData.view = {};
|
|||
|
transData.view.imagePadding = 0;
|
|||
|
if(typeof(imagePadding) != 'undefined'){
|
|||
|
transData.view.imagePadding = imagePadding
|
|||
|
}
|
|||
|
var bindData = {};
|
|||
|
bindData[bindName] = transData;
|
|||
|
that.setData(bindData)
|
|||
|
that.wxParseImgLoad = wxParseImgLoad;
|
|||
|
that.wxParseImgTap = wxParseImgTap;
|
|||
|
}
|
|||
|
// 图片点击事件
|
|||
|
function wxParseImgTap(e) {
|
|||
|
var that = this;
|
|||
|
var nowImgUrl = e.target.dataset.src;
|
|||
|
var tagFrom = e.target.dataset.from;
|
|||
|
if (typeof (tagFrom) != 'undefined' && tagFrom.length > 0) {
|
|||
|
wx.previewImage({
|
|||
|
current: nowImgUrl, // 当前显示图片的http链接
|
|||
|
urls: that.data[tagFrom].imageUrls // 需要预览的图片http链接列表
|
|||
|
})
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* 图片视觉宽高计算函数区
|
|||
|
**/
|
|||
|
function wxParseImgLoad(e) {
|
|||
|
var that = this;
|
|||
|
var tagFrom = e.target.dataset.from;
|
|||
|
var idx = e.target.dataset.idx;
|
|||
|
if (typeof (tagFrom) != 'undefined' && tagFrom.length > 0) {
|
|||
|
calMoreImageInfo(e, idx, that, tagFrom)
|
|||
|
}
|
|||
|
}
|
|||
|
// 假循环获取计算图片视觉最佳宽高
|
|||
|
function calMoreImageInfo(e, idx, that, bindName) {
|
|||
|
var temData = that.data[bindName];
|
|||
|
if (!temData || temData.images.length == 0) {
|
|||
|
return;
|
|||
|
}
|
|||
|
var temImages = temData.images;
|
|||
|
//因为无法获取view宽度 需要自定义padding进行计算,稍后处理
|
|||
|
var recal = wxAutoImageCal(e.detail.width, e.detail.height,that,bindName);
|
|||
|
// temImages[idx].width = recal.imageWidth;
|
|||
|
// temImages[idx].height = recal.imageheight;
|
|||
|
// temData.images = temImages;
|
|||
|
// var bindData = {};
|
|||
|
// bindData[bindName] = temData;
|
|||
|
// that.setData(bindData);
|
|||
|
var index = temImages[idx].index
|
|||
|
var key = `${bindName}`
|
|||
|
for (var i of index.split('.')) key+=`.nodes[${i}]`
|
|||
|
var keyW = key + '.width'
|
|||
|
var keyH = key + '.height'
|
|||
|
that.setData({
|
|||
|
[keyW]: recal.imageWidth,
|
|||
|
[keyH]: recal.imageheight,
|
|||
|
})
|
|||
|
}
|
|||
|
|
|||
|
// 计算视觉优先的图片宽高
|
|||
|
function wxAutoImageCal(originalWidth, originalHeight,that,bindName) {
|
|||
|
//获取图片的原始长宽
|
|||
|
var windowWidth = 0, windowHeight = 0;
|
|||
|
var autoWidth = 0, autoHeight = 0;
|
|||
|
var results = {};
|
|||
|
var padding = that.data[bindName].view.imagePadding;
|
|||
|
windowWidth = realWindowWidth-2*padding;
|
|||
|
windowHeight = realWindowHeight;
|
|||
|
//判断按照那种方式进行缩放
|
|||
|
// console.log("windowWidth" + windowWidth);
|
|||
|
if (originalWidth > windowWidth) {//在图片width大于手机屏幕width时候
|
|||
|
autoWidth = windowWidth;
|
|||
|
// console.log("autoWidth" + autoWidth);
|
|||
|
autoHeight = (autoWidth * originalHeight) / originalWidth;
|
|||
|
// console.log("autoHeight" + autoHeight);
|
|||
|
results.imageWidth = autoWidth;
|
|||
|
results.imageheight = autoHeight;
|
|||
|
} else {//否则展示原来的数据
|
|||
|
results.imageWidth = originalWidth;
|
|||
|
results.imageheight = originalHeight;
|
|||
|
}
|
|||
|
return results;
|
|||
|
}
|
|||
|
|
|||
|
function wxParseTemArray(temArrayName,bindNameReg,total,that){
|
|||
|
var array = [];
|
|||
|
var temData = that.data;
|
|||
|
var obj = null;
|
|||
|
for(var i = 0; i < total; i++){
|
|||
|
var simArr = temData[bindNameReg+i].nodes;
|
|||
|
array.push(simArr);
|
|||
|
}
|
|||
|
|
|||
|
temArrayName = temArrayName || 'wxParseTemArray';
|
|||
|
obj = JSON.parse('{"'+ temArrayName +'":""}');
|
|||
|
obj[temArrayName] = array;
|
|||
|
that.setData(obj);
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* 配置emojis
|
|||
|
*
|
|||
|
*/
|
|||
|
|
|||
|
function emojisInit(reg='',baseSrc="/wxParse/emojis/",emojis){
|
|||
|
HtmlToJson.emojisInit(reg,baseSrc,emojis);
|
|||
|
}
|
|||
|
|
|||
|
module.exports = {
|
|||
|
wxParse: wxParse,
|
|||
|
wxParseTemArray:wxParseTemArray,
|
|||
|
emojisInit:emojisInit
|
|||
|
}
|
|||
|
|
|||
|
|