主要观点总结
这段代码主要实现了微信小程序的文本描述信息的渲染和设置功能,包括处理关键词的渲染、文本内容的过滤和替换、以及不同页面类型的描述内容展示。
关键观点总结
关键观点1: 关键词渲染
通过函数`renderKeyWord`和`addKeywordToHtml`实现了关键词的渲染,使关键词在文本中高亮显示,并添加额外的样式类。
关键观点2: 文本内容过滤和替换
使用`replaceTagChar`函数进行HTML标签的替换,以防止XSS攻击,并使用正则表达式进行特定字符的替换。
关键观点3: 页面类型描述展示
根据页面类型(如音频、图片、搜索等)设置不同的描述展示方式,例如音频描述展示在音频详情页,图片描述展示在图片详情页,而普通文本描述展示在通用分享页面。
关键观点4: 页面内容编码处理
使用`__setDesc`函数处理页面内容的编码问题,支持对文本内容进行编码或解码,以及是否保留特定内容。
文章预览
var __INLINE_SCRIPT__ = (function () {
'use strict';
function _arrayLikeToArray$2(arr, len) {
if (len == null || len > arr.length) len = arr.length;
for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
return arr2;
}
function _arrayWithoutHoles(arr) {
if (Array.isArray(arr)) return _arrayLikeToArray$2(arr);
}
function _iterableToArray(iter) {
if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
}
function _unsupportedIterableToArray$2(o, minLen) {
if (!o) return;
if (typeof o === "string") return _arrayLikeToArray$2(o, minLen);
var n = Object.prototype.toString.call(o).slice(8, -1);
if (n === "Object" && o.constructor) n = o.constructor.name;
if (n === "Map" || n === "Set") return Array.from(o);
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray$2(o, minLen);
}
function
………………………………