亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > CMS > 織夢DEDE > 正文

織夢ueditor百度編輯器div style被過濾解決辦法

2024-07-12 09:11:21
字體:
來源:轉載
供稿:網友

開發中有用到開源的富文本編輯器UEditor,在使用的過程中遇到了樣式被過濾無法顯示問題,經過一番折騰終解決,此外,還有一些關于獲取前臺界面元素的一些總結。

1. UEditor樣式被過濾無法顯示問題

         上周有用到百度開源的富文本編輯器----UEditor.不得不說這個富文本編輯器做的真的很贊,個人覺得比CKeditor要好用很多,效果也很不錯。

但是在使用的過程中,有遇到在向文本編輯器插入HTML文本時,添加的樣式老是被過濾掉,找了很多的資料,并結合最新的版本,整理了下如何解決樣式過濾的方法。

我們在富文本編輯頁點擊HTML小圖標,切換到HTML模式,然后在該模式下加入如下HTML:

<style type="text/css">.bg{ background:lightbule;}</style><div class="bg">Hello EveryBody Welcome To UEditor World!</div>

以上的html意思很簡單,就是為div加了一個名為bg 的樣式,

然后我們再點擊HTML圖標,轉換到預覽頁,可以看到我們的div的背景色并沒有任何的變化,而且我們在div之前寫的樣式,也沒有被渲染,

反而是以文本的形式顯示了出來。F12查看整個頁面,發現我們之前寫的樣式和標簽都被渲染成如下的html:

<div style="display: none;" cdata_tag="style" type="text/css"><p>Hello EveryBody Welcome To UEditor World!</p>

由以上代碼可以看出,我們的style標簽被轉換成了div,并且設置樣式為不可見,我們的div標簽被轉換成了p標簽。

這說明編輯器本身自己做了一個轉換,類似于一個過濾吧,可能是為了出于安全性考慮,防止用戶在前段輸入非法的代碼、腳本等,事實上我覺得這有點多此一舉,

既然都讓富文本編輯了,不能寫html腳本,還叫什么富文本。

然后我們再點擊HTML圖標,看看HTML試圖,內容如下:

<style type="text/css">.bg{ background:lightbule;}</style><p>Hello EveryBody Welcome To UEditor World!</p>

結合以上分析得出,該編輯器內部過濾機制是將style標記轉換為div,而將div等標簽以p替代。如何解決呢?

之前有在網上查過相關的資料,都說是在配置文件里有一個黑白名單,然后就在配置文件里找了下,在最新版本的腳本文件里怎么找也沒找到那個所謂的黑白名單,

當然了,沒有黑白名單也照樣可以解決問題的。

首先在ueditor.all.js文件內搜索allowDivTransToP,找到如下的代碼,將true設置為false

me.setOpt('allowDivTransToP',false);//默認的過濾處理//進入編輯器的內容處理然后再接著下邊的addInputRule方法中將switch代碼段中的case style,script都給注釋或者刪掉。me.addInputRule(function (root) {var allowDivTransToP = this.options.allowDivTransToP;var val;//進行默認的處理root.traversal(function (node) {if (node.type == 'element') {if (!dtd.$cdata[node.tagName] && me.options.autoClearEmptyNode && dtd.$inline[node.tagName] && !dtd.$empty[node.tagName] && (!node.attrs || utils.isEmptyObject(node.attrs))) {if (!node.firstChild()) node.parentNode.removeChild(node);else if (node.tagName == 'span' && (!node.attrs || utils.isEmptyObject(node.attrs))) {node.parentNode.removeChild(node, true)}return;}//刪除switch下的case style 和scriptswitch (node.tagName) {case 'a':if (val = node.getAttr('href')) {node.setAttr('_href', val)}break;

完成以上操作之后,保存即可。再次插入html時,樣式就可以顯示了。

解釋一下以上操作的意義。

第一步將allowDivTransToP設置為false是因為默認的設置是將div自動轉換為p,這樣寫好的樣式就找不到相應的div

了,所以才渲染不上的。

第二步將addInputRule函數中的switch 代碼段中的case style ,script選擇給刪除或者注釋,是為了避免出現編輯器將style或script自動的轉換成別的標簽。

好了,大家可以試一試,看看效果。

 

2.JQuery.attr()與JQuery.css()的區別

     之前一直沒太區分attr()與css,今天好好看了下,css和attr作用的范圍不同,css主要是用來設置樣式的,也就是style內的東西,而attr主要是用來設置屬性的,比如元素的title,name、style等這些都可以稱之為屬性,舉例說明

  <input  id="btn"  type="button" value="確定” />

我們可以用$("#btn").css("background","green");為該按鈕設置一個背景色,

而如果我們這樣寫$("#btn").attr("background","green");不但按鈕的背景色不會發生變化,相反該按鈕在頁面渲染之后又多了一個background的屬性,請注意,這里是屬性,而不是style里邊的background,頁面的渲染如下:

<input  id="btn"  type="button" value="確定”  background="green" />

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品v日韩精品| 欧美极品少妇xxxxⅹ裸体艺术| 欧美三级xxx| 亚洲成人亚洲激情| 欧美一区第一页| 黑人巨大精品欧美一区免费视频| 欧美日韩一区二区精品| 亚洲天堂男人的天堂| 久久精品成人动漫| 国产成人av在线| 精品一区二区三区电影| 中文字幕亚洲色图| 欧美日韩在线看| 午夜精品三级视频福利| 欧美成人剧情片在线观看| 色婷婷综合久久久久中文字幕1| 国产综合久久久久| 欧美精品在线视频观看| 色播久久人人爽人人爽人人片视av| 国产va免费精品高清在线观看| 久久精品99久久久香蕉| 茄子视频成人在线| 久热爱精品视频线路一| 欧美日韩午夜视频在线观看| 欧美成人三级视频网站| 欧美尤物巨大精品爽| 国产精品大陆在线观看| 国产精品极品尤物在线观看| 国产亚洲欧美视频| 亚洲国产日韩欧美综合久久| 日韩av影视在线| 亚洲人成电影网站色www| 亚洲高清在线观看| 亚洲精品日韩激情在线电影| 成人免费大片黄在线播放| 亚洲图片在线综合| 一区二区在线免费视频| 国产日韩在线精品av| 亚洲成年人在线播放| 欧美高清一级大片| 日韩欧美大尺度| 欧美精品一区三区| 日韩在线观看成人| 成人激情视频小说免费下载| 爱福利视频一区| 成人福利网站在线观看11| 久久久久国色av免费观看性色| 国产91亚洲精品| 亚洲一区亚洲二区亚洲三区| 精品人伦一区二区三区蜜桃免费| 欧美性感美女h网站在线观看免费| 狠狠综合久久av一区二区小说| 疯狂做受xxxx高潮欧美日本| 国产精品久久久久久久久久久久| 国产成人精品久久| 成人性生交大片免费看小说| 日韩免费观看高清| 国产精品第一页在线| 亚洲人成电影网站色| 国产精品三级网站| 91色琪琪电影亚洲精品久久| 97精品国产97久久久久久| 国产精品91久久久久久| 国产精品无码专区在线观看| 久久久在线免费观看| 久久久久久久久久av| 国产精品日日摸夜夜添夜夜av| 国产精品视频xxx| 国产福利成人在线| 国产黑人绿帽在线第一区| 蜜臀久久99精品久久久无需会员| 欧美激情国产高清| 国产精品爱啪在线线免费观看| 日韩成人在线观看| 国产日韩欧美在线播放| 中文字幕日韩欧美在线视频| 国内精品中文字幕| 激情成人在线视频| 欧美中文字幕精品| 91人人爽人人爽人人精88v| 日韩成人小视频| 大伊人狠狠躁夜夜躁av一区| 国产日韩欧美电影在线观看| 欧美性xxxxx极品娇小| 精品视频久久久久久久| 亚洲欧洲美洲在线综合| 亚洲男子天堂网| 永久555www成人免费| 2019精品视频| 国产91久久婷婷一区二区| 亚洲女人被黑人巨大进入al| 91国在线精品国内播放| 国产精品尤物福利片在线观看| 亚洲欧美国内爽妇网| 色一区av在线| 成人免费网站在线| 97香蕉久久夜色精品国产| 26uuu另类亚洲欧美日本老年| 成人疯狂猛交xxx| 91中文在线观看| 亚洲春色另类小说| 欧美日韩精品国产| 亚洲aaaaaa| 川上优av一区二区线观看| 国产午夜精品视频免费不卡69堂| 成人www视频在线观看| 亚洲free性xxxx护士hd| 欧美性猛交99久久久久99按摩| 精品久久香蕉国产线看观看亚洲| 亚洲码在线观看| 插插插亚洲综合网| 国产精国产精品| 茄子视频成人在线| 国产69精品久久久| www.亚洲成人| 国产精品黄页免费高清在线观看| 亚洲女人天堂av| 欧美激情日韩图片| 亚洲激情小视频| 45www国产精品网站| 欧美成人免费在线视频| 伊人久久大香线蕉av一区二区| 亚洲精品电影在线| 欧美激情精品久久久久久久变态| 91中文字幕在线| 疯狂做受xxxx高潮欧美日本| 欧美一区二区大胆人体摄影专业网站| 久久精品国产一区| 亚洲成av人乱码色午夜| 中文字幕在线看视频国产欧美| 日韩精品在线电影| 欧美精品久久久久久久久| 久久av资源网站| 久久久精品久久| 国产精品一久久香蕉国产线看观看| 992tv成人免费视频| 91久久精品国产91久久| 亚洲精选在线观看| 亚洲国产成人爱av在线播放| 成人a免费视频| 久久人人看视频| 97欧美精品一区二区三区| 国产乱人伦真实精品视频| 亚洲精品资源在线| 亚洲人成在线观看| 国产精品久久999| 日韩精品免费在线观看| 欧美电影在线观看| 成人一区二区电影| 久久成人亚洲精品| 久久精品一区中文字幕| 91精品视频在线播放| 日本国产欧美一区二区三区| 久久久精品在线观看| 国外成人免费在线播放| 97涩涩爰在线观看亚洲| 国产福利精品视频| 亚洲天堂精品在线| 亚洲精品一区二区三区婷婷月| 97在线观看视频国产| 欧美在线视频一二三| 国产精品十八以下禁看| 精品国产乱码久久久久久虫虫漫画| 欧美激情一区二区三区成人|