摘要:主要采用了原生與調(diào)用結(jié)合的功能實現(xiàn)功能。所以根據(jù)這種方法,讀者可以根據(jù)自己的需求添加更多的功能,比如在編輯框里面插入一個可以點擊的標(biāo)簽或者添加一個代碼塊希望能讀到此文章的讀者,能在下方一起交流,更希望大佬提出錯誤,謝謝地址
因為一個同學(xué),要做一個能加入圖片的留言板功能,類型與QQ空間留言板和百度貼吧發(fā)帖的那種形式,同時在網(wǎng)上找了找發(fā)生網(wǎng)上對這方面的交流很少,所以發(fā)表這篇文章拋磚引玉,希望能幫助廣大的學(xué)習(xí)者,也同時希望大佬能對此文章及本人寫的代碼,不吝賜教。
主要采用了原生JS與調(diào)用Selection API結(jié)合html的contentible功能實現(xiàn)功能。
1.先來看看效果
2.主要功能
1.在當(dāng)前光標(biāo)位置添加指定圖片,并=點擊以后修改圖片大小 2.修改選中文字的大小,字體顏色及添加斜體、粗體、下劃線
3.代碼及一些難點部分
首先看一個很很很關(guān)鍵和重要的函數(shù)
function getSelectionRange() { var select; //兼容處理 if (window.getSelection) { select = window.getSelection(); range = select.getRangeAt(0);//獲取selection對象,并獲取range對象 } else if (document.selection) { //IE瀏覽器 range = document.selection.createRange();//IE可以直接獲取 }; };
這個函數(shù)是調(diào)用seleciton API并用range保存當(dāng)前光標(biāo)位置,方便后面插入圖片和給代碼修改文字樣式
其次另外一個也很關(guān)鍵的函數(shù)是
//插入節(jié)點 function insert(newNode){ var fragNode = document.createDocumentFragment().appendChild(newNode);//創(chuàng)建文檔碎片并放入新節(jié)點 range.deleteContents();//刪除Rnge中的內(nèi)容 range.insertNode(fragNode);//再插入新碎片 }
這個函數(shù)接收一個新的也就是要插入節(jié)點的形參,然后刪除當(dāng)前位置的內(nèi)容(如果選中的是文字這把當(dāng)前這選中的文字刪除掉)最后把新創(chuàng)建的節(jié)點插入到光標(biāo)的位置。
我們在來看看另外一個難點部分,就是獲取選中的文字,,這里我采用的是鼠標(biāo)的監(jiān)聽事件,mousedown->mousemove->mouseup,分別的監(jiān)聽,來判斷是否鼠標(biāo)發(fā)生移動,及得到鼠標(biāo)選中的文本
//獲取選中的字符 edit.addEventListener("click",function(){ getSelectionRange();//獲取Range }); edit.addEventListener("mousedown",function(){ edit.addEventListener("mousemove",listenMove); }); function listenMove(){ moved=true; }; edit.addEventListener("mouseup",function(){ if(!moved){ return; } //當(dāng)有選中內(nèi)容才進(jìn)行操作 edit.removeEventListener("mousemove",listenMove); getSelectionRange(); selectTxt= range.toString();//將選擇的內(nèi)容從對象中提取出來,直接轉(zhuǎn)字符串就行了。 moved = false; });
先在mousedown函數(shù)里面獲取一次range,然后在mouseup的函數(shù)里面再次獲取range得到選中的文字用selectTxt保存,這里在我看來只要是理清楚思路這里很好理解。
到了這里我們就已經(jīng)把幾個比較困難的問題解決了,剩下的插入文字和圖片及改變圖片的大小,都是很簡單的基本操作。
我以插入圖片為例,大家可以拿到代碼以后自己理一理插入文字的思路:
//插入圖片 var imgSrc=""; aInsertBtn[0].onclick=function(){ var txt=document.getElementById("txtImg"); //如果同時存在本地上傳圖片和網(wǎng)絡(luò)圖片的地址,只插入網(wǎng)絡(luò)圖片 console.log(txt.value) if(txt.value){ imgSrc=txt.value; txt.value=" "; } addImg(imgSrc); insertImg.style.display="none"; } function fileChange(){ var val=this.value.toLowerCase().split("."); if(val){ if(val[1]=="gif"||val[1]=="png"||val[1]=="jpg"||val[1]=="jpeg"){ var reader = new FileReader(); reader.onload = function (e) { imgSrc = e.target.result; } reader.readAsDataURL(this.files[0]); }else{ alert("目前支持gif,png,jpg,jpeg格式的圖片!") } } } function addImg(src){ var newImg=new Image(); newImg.className="insertNewImg"; newImg.src=src; insert(newImg); }
這里需特別的說明一下,如果是插入的是本地圖片,由于瀏覽器為了安全限制file.value并不是圖片的真實地址,換句話說img.src=file.value是得不到圖片的,所以這里我們需要借用FileReader對象來得到真實的圖片地址,當(dāng)然這里網(wǎng)絡(luò)的圖片地址肯定是可以直接用的,然后將的到的src地址傳入addImg函數(shù)生成img節(jié)點以后插入當(dāng)前光標(biāo)指向的文本位置。
所以添加文本樣式也是一樣的方法,無非就是在創(chuàng)建完文本節(jié)點以后給他添加style樣式。
所以根據(jù)這種方法,讀者可以根據(jù)自己的需求添加更多的功能,比如:在編輯框里面插入一個可以點擊的a標(biāo)簽或者添加一個代碼塊.....
希望能讀到此文章的讀者,能在下方一起交流,更希望大佬提出錯誤,謝謝!!!
GitHub地址:https://github.com/LiChangyi/...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/51378.html
摘要:主要采用了原生與調(diào)用結(jié)合的功能實現(xiàn)功能。所以根據(jù)這種方法,讀者可以根據(jù)自己的需求添加更多的功能,比如在編輯框里面插入一個可以點擊的標(biāo)簽或者添加一個代碼塊希望能讀到此文章的讀者,能在下方一起交流,更希望大佬提出錯誤,謝謝地址 因為一個同學(xué),要做一個能加入圖片的留言板功能,類型與QQ空間留言板和百度貼吧發(fā)帖的那種形式,同時在網(wǎng)上找了找發(fā)生網(wǎng)上對這方面的交流很少,所以發(fā)表這篇文章拋磚引玉,希...
摘要:使用實現(xiàn)桌面應(yīng)用實現(xiàn)離線可用很多方法,比如使用技術(shù)。還有一個好處,因為它完全基于來實現(xiàn)可以使用的一些新功能,那我們理論上可以在做桌面應(yīng)用時順手把應(yīng)用也做了。 本文將會講述一個完整的跨端桌面應(yīng)用?代碼畫板?的構(gòu)建,會涉及到整個軟件開發(fā)流程,從開始的設(shè)計、編碼、到最后產(chǎn)品成型、包裝等。 本文不僅僅是一篇技術(shù)方面的專業(yè)文章,更會有很多產(chǎn)品方面的設(shè)計思想和將技術(shù)轉(zhuǎn)換成生產(chǎn)力的思考,我將結(jié)合我自...
摘要:用原生寫一個多動癥的簡歷預(yù)覽地址源碼地址最近在知乎上看到方應(yīng)杭用寫了一個會動的簡歷,覺得挺好玩的,研究一下其實現(xiàn)思路,決定試試用原生來實現(xiàn)。 用原生js寫一個多動癥的簡歷 預(yù)覽地址源碼地址 最近在知乎上看到@方應(yīng)杭用vue寫了一個會動的簡歷,覺得挺好玩的,研究一下其實現(xiàn)思路,決定試試用原生js來實現(xiàn)。 showImg(https://segmentfault.com/img/remot...
閱讀 2031·2021-09-29 09:35
閱讀 1958·2019-08-30 14:15
閱讀 2981·2019-08-30 10:56
閱讀 968·2019-08-29 16:59
閱讀 581·2019-08-29 14:04
閱讀 1315·2019-08-29 12:30
閱讀 1033·2019-08-28 18:19
閱讀 519·2019-08-26 11:51