首页 > 网站 > 建站经验 > 正文

解决KindEditor4.1.3图片和链接属性中冒号被替换为%3A的问题

2024-04-25 20:30:24
字体:
来源:转载
供稿:网友

KindEditor4.1.3可能在链接地址的escape上出了点问题,发过的帖子再编辑时修改帖子中链接或图片的src时url中的:会被escape,变为%3A,虽然不影响编辑后的结果,但难免看起来会引起误会。

解决KindEditor4.1.3图片和链接属性中冒号被替换为%3A的问题

看了下KE的源码,发现问题出在beforeSetHtml方法中,下面是此方法代码:

self.beforeSetHtml(function(html) {        return html.replace(/<embed[^>]*type="([^"]+)"[^>]*>(?:<//embed>)?/ig, function(full) {            var attrs = _getAttrList(full);            attrs.src = _undef(attrs.src, '');            attrs.width = _undef(attrs.width, 0);            attrs.height = _undef(attrs.height, 0);            return _mediaImg(self.themesPath + 'common/blank.gif', attrs);        })        .replace(/<a[^>]*name="([^"]+)"[^>]*>(?:<//a>)?/ig, function(full) {            var attrs = _getAttrList(full);            if (attrs.href !== undefined) {                return full;            }            return '<img class="ke-anchor" src="' + self.themesPath + 'common/anchor.gif" data-ke-name="' + escape(attrs.name) + '" />';        })        .replace(/<script([^>]*)>([/s/S]*?)<//script>/ig, function(full, attr, code) {            return '<div class="ke-script" data-ke-script-attr="' + escape(attr) + '">' + escape(code) + '</div>';        })        .replace(/<noscript([^>]*)>([/s/S]*?)<//noscript>/ig, function(full, attr, code) {            return '<div class="ke-noscript" data-ke-noscript-attr="' + escape(attr) + '">' + escape(code) + '</div>';        })        .replace(/(<[^>]*)(href|src)="([^"]*)"([^>]*>)/ig, function(full, start, key, src, end) {            if (full.match(//sdata-ke-src="[^"]*"/i)) {                return full;            }            full = start + key + '="' + src + '"' + ' data-ke-src="' + escape(src) + '"' + end;            return full;        })        .replace(/(<[^>]+/s)(on/w+="[^"]*"[^>]*>)/ig, function(full, start, end) {            return start + 'data-ke-' + end;        })        .replace(/<table[^>]*/s+border="0"[^>]*>/ig, function(full) {            if (full.indexOf('ke-zeroborder') >= 0) {                return full;            }            return _addClassToTag(full, 'ke-zeroborder');        });    });

问题是由下面这一行代码导致的,DEBUG了下,这里的escape是浏览器的native方法,而不是K.escape:

full = start + key + '="' + src + '"' + ' data-ke-src="' + escape(src) + '"' + end;

解决方法:

将escape(src)改为src或者_escape(src),武林网上编辑器已更新。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表