尤明明Blog

网站建设 | 前端切图,技术不仅是一种专业,更是一种责任!

您的当前位置: 首页 » 前端学习 » js常用代码 »

解决UEditor样式被过滤、li标签自动添加p问题

2024-02-22   Umming   js常用代码    评论(0)    浏览(935)


解决UEditor样式被过滤问题
找到ueditor.all.js;

“简单粗暴法”:在文件ueditor.all.js中,有个函数 UE.plugins['defaultfilter'] = function(){......},上面注释为,编辑器默认的过滤转换机制。可在函数开头直接添加 return 语句,使所有过滤机制都不生效。

Nzk1LnBuZw.png

搜索notTransAttrs,这个是配置不需要过滤的属性

var notTransAttrs = {
    'href':1,
    'src':1,
    '_src':1,
    '_href':1,
    'class':1,
};

搜索notTransTagName ,这个是配置不需要过滤的标签
var notTransTagName = {
        pre:1,
        style:1,
        script:1,
        div:1,
        p:1,
        ul:1,
        li:1,
        table:1
}

li标签自动添加p问题
1、找到ueditor.all.js(我引用的是ueditor.all.js,有的人用的是ueditor.all.min.js)
2、搜索utils.each(root.getNodesByTagName('li'),function(li) 就可以找到以下代码,删掉或注释
//导出时,去掉p标签
//me.getOpt('disablePInList') === true && me.addOutputRule(function(root){
//    utils.each(root.getNodesByTagName('li'),function(li){
//        var newChildrens = [],index=0;
//        utils.each(li.children,function(n){
//            if(n.tagName == 'p'){
//                var tmpNode;
//                while(tmpNode = n.children.pop()) {
//                    newChildrens.splice(index,0,tmpNode);
//                    tmpNode.parentNode = li;
//                    lastNode = tmpNode;
//                }
//                tmpNode = newChildrens[newChildrens.length-1];
//                if(!tmpNode || tmpNode.type != 'element' || tmpNode.tagName != 'br'){
//                    var br = UE.uNode.createElement('br');
//                    br.parentNode = li;
//                    newChildrens.push(br);
//                }
 
//                index = newChildrens.length;
//            }
//        });
//        if(newChildrens.length){
//            li.children = newChildrens;
//        }
//    });
//});
//进入编辑器的li要套p标签
//me.addInputRule(function(root){
//    utils.each(root.getNodesByTagName('li'),function(li){
//        var tmpP = UE.uNode.createElement('p');
//        for(var i= 0,ci;ci=li.children[i];){
//            if(ci.type == 'text' || dtd.p[ci.tagName]){
//                tmpP.appendChild(ci);
//            }else{
//                if(tmpP.firstChild()){
//                    li.insertBefore(tmpP,ci);
//                    tmpP = UE.uNode.createElement('p');
//                    i = i + 2;
//                }else{
//                    i++;
//                }
 
//            }
//        }
//        if(tmpP.firstChild() && !tmpP.parentNode || !li.firstChild()){
//            li.appendChild(tmpP);
//        }
//        //trace:3357
//        //p不能为空
//        if (!tmpP.firstChild()) {
//            tmpP.innerHTML(browser.ie ? '&nbsp;' : '<br/>')
//        }
//        //去掉末尾的空白
//        var p = li.firstChild();
//        var lastChild = p.lastChild();
//        if(lastChild && lastChild.type == 'text' && /^\s*$/.test(lastChild.data)){
//            p.removeChild(lastChild)
//        }
//    });
//    if(me.options.autoTransWordToList){
//        var orderlisttype = {
//                'num1':/^\d+\)/,
//                'decimal':/^\d+\./,
//                'lower-alpha':/^[a-z]+\)/,
//                'upper-alpha':/^[A-Z]+\./,
//                'cn':/^[\u4E00\u4E8C\u4E09\u56DB\u516d\u4e94\u4e03\u516b\u4e5d]+[\u3001]/,
//                'cn2':/^\([\u4E00\u4E8C\u4E09\u56DB\u516d\u4e94\u4e03\u516b\u4e5d]+\)/
//            },
//            unorderlisttype = {
//                'square':'n'
//            };
//        function checkListType(content,container){
//            var span = container.firstChild();
//            if(span &&  span.type == 'element' && span.tagName == 'span' && /Wingdings|Symbol/.test(span.getStyle('font-family'))){
//                for(var p in unorderlisttype){
//                    if(unorderlisttype[p] == span.data){
//                        return p
//                    }
//                }
//                return 'disc'
//            }
//            for(var p in orderlisttype){
//                if(orderlisttype[p].test(content)){
//                    return p;
//                }
//            }
 
//        }
//        utils.each(root.getNodesByTagName('p'),function(node){
//            if(node.getAttr('class') != 'MsoListParagraph'){
//                return
//            }
 
//            //word粘贴过来的会带有margin要去掉,但这样也可能会误命中一些央视
//            node.setStyle('margin','');
//            node.setStyle('margin-left','');
//            node.setAttr('class','');
 
//            function appendLi(list,p,type){
//                if(list.tagName == 'ol'){
//                    if(browser.ie){
//                        var first = p.firstChild();
//                        if(first.type =='element' && first.tagName == 'span' && orderlisttype[type].test(first.innerText())){
//                            p.removeChild(first);
//                        }
//                    }else{
//                        p.innerHTML(p.innerHTML().replace(orderlisttype[type],''));
//                    }
//                }else{
//                    p.removeChild(p.firstChild())
//                }
 
//                var li = UE.uNode.createElement('li');
//                li.appendChild(p);
//                list.appendChild(li);
//            }
//            var tmp = node,type,cacheNode = node;
 
//            if(node.parentNode.tagName != 'li' && (type = checkListType(node.innerText(),node))){
 
//                var list = UE.uNode.createElement(me.options.insertorderedlist.hasOwnProperty(type) ? 'ol' : 'ul');
//                if(customStyle[type]){
//                    list.setAttr('class','custom_'+type)
//                }else{
//                    list.setStyle('list-style-type',type)
//                }
//                while(node && node.parentNode.tagName != 'li' && checkListType(node.innerText(),node)){
//                    tmp = node.nextSibling();
//                    if(!tmp){
//                        node.parentNode.insertBefore(list,node)
//                    }
//                    appendLi(list,node,type);
//                    node = tmp;
//                }
//                if(!list.parentNode && node && node.parentNode){
//                    node.parentNode.insertBefore(list,node)
//                }
//            }
//            var span = cacheNode.firstChild();
//            if(span && span.type == 'element' && span.tagName == 'span' && /^\s*(&nbsp;)+\s*$/.test(span.innerText())){
//                span.parentNode.removeChild(span)
//            }
//        })
//    }
 
//});

标签: ueditor

本文链接:https://www.umming.com/js/323.html

声明:本站信息由网友自行发布或来源于网络,真实性、合法性由发布人负责,请仔细甄别!本站只为传递信息,我们不做任何双方证明,也不承担任何法律责任。文章内容若侵犯你的权益,请联系本站删除!


发表评论:

//