|
|

楼主 |
发表于 2023-12-9 09:44
|
显示全部楼层
三、JS(xd_editor.js)
- (function() {
- let xdForm = document.querySelector('form');
- if(!xdForm) return false;
- /* 创建界面 */
- let xdEditor = document.createElement('div');
- let picData = '';
- xdEditor.id = 'ed_outer';
- xdEditor.innerHTML = `
- <div id="ed_top">
- <button type="button" id="code" class="btn" title="代码模式"></button>
- <span id="font_color" class="btn" title="字体前景色">
- <input id="forecolor" class="colorBox" type="color" value="#ff0000" />
- </span>
- <span id="bg_color" class="btn" title="字体背景色">
- <input id="backcolor" class="colorBox" type="color" value="#0000ff" />
- </span>
- <button type="button" id="bold" class="btn" title="加粗"></button>
- <button type="button" id="italic" class="btn" title="斜体"></button>
- <button type="button" id="underline" class="btn" title="下划线"></button>
- <button type="button" id="strikethrough" class="btn" title="删除线"></button>
- <button type="button" id="removeformat" class="btn" title="清除格式"></button>
- <span id="edlist" class="btn" title="列表">
- <select id="orderlist">
- <option value="0">列表</option>
- <option value="insertorderedlist">有序列表</option>
- <option value="insertunorderedlist">无序列表</option>
- </select>
- </span>
- <button type="button" id="image" class="btn" title="图片"></button>
- <button type="button" id="audio" class="btn" title="音频"></button>
- <button type="button" id="video" class="btn" title="视频"></button>
- <span class="grow1"><a href="./" title="回退">返回日记</a></span>
- </div>
- <div id="ed_edit">
- <div id="rDiv" contenteditable="true"><p><br></p></div>
- </div>
- <div id="ed_foot">
- <span class="grow1"></span>
- <input type="submit" id="sub" name="sub" value="发布" title="提交" />
- </div>
- <div id="insertBox">
- <p id="mtitle" class="mid bold">插入</p>
- <p><label for="oSrc">地址 : </lable><input id="oSrc" type="text" value=""/ size="60" ></p>
- <p>
- <span id="s1"><label for="oWidth">宽度 : </lable><input id="oWidth" type="text" value="" size="4" /></span>
- <span id="s2"><label for="oHeight">高度 : </lable><input id="oHeight" type="text" value="" size="4" /></span>
- <span id="s3"><label for="oTitle">提示 : </lable><input id="oTitle" type="text" value="" size="8" /></span>
- <span id="s4"><input id="oCtrl" type="checkbox" value="" /><label for="oCtrl">控制</lable></span>
- <span id="s5"><input id="oAuto" type="checkbox" value="" /><label for="oAuto">自动</lable></span>
- <span id="s6"><input id="oLoop" type="checkbox" value="" /><label for="oLoop">循环</lable></span>
- </p>
- <p class="right"><input id="btnInsert" type="button" value="确定" /></p>
- </div>
- `;
- xdForm.appendChild(xdEditor); /* div追加到form */
- ed_edit.append(elm); /* textarea加入界面 */
- let codeState = false, insertIdx = 0; /* codeState : 编辑模式;insertIdx : 插入媒体索引 */
- /* btns : 所有按钮;colors : 插入颜色box;exec_btns : 一级执行按钮;media_btns :媒体按钮 */
- let btns = document.querySelectorAll('.btn'),
- colors = document.querySelectorAll('.colorBox');
- let exec_btns = ['bold','italic','underline','strikethrough','removeformat'],
- media_btns = ['image','audio','video'];
- let icon = {bold: 7,italic: 8,underline: 9,strikethrough: 10,font_color: 11,bg_color: 12,removeformat: 14,edlist: 16,image: 22,video: 23,audio: 24,code: 28};
- /* 函数 : 简单格式化代码 */
- let formatCode = (code) => {
- let regAr = [
- [/(<\/p>|<\/div>)(<)/g, '$1\n$2'],
- [/<div>(<br>)?<\/div>|<p><\/p>/g, ''],
- [/^[\t]*\n/gm, '']
- ];
- regAr.forEach((item) => {
- code = code.replaceAll(item[0],item[1]);
- });
- return code;
- };
- /* 函数 : 工具条按钮组隐藏|显示 */
- let set_btnState = () => {
- btns.forEach((btn,key) => {
- if(key > 0) btn.style.display = ['inline-block','none'][Number(codeState)];
- });
- };
- /* 函数 : 隐藏|显示元素,数组传参,用于插入媒体box */
- let hideEle = (hEles,sEles) => {
- hEles.forEach((hEle) => hEle.style.display = 'none');
- sEles.forEach((sEle) => sEle.style.display = 'inline-block');
- };
- /* 工具条按钮上图+功能处理 */
- btns.forEach((item) => {
- let num = icon[item.id];
- item.style.background = `url(${picData}) -${num * 20}px 0`;
- item.onclick = () => {
- if(exec_btns.includes(item.id)) document.execCommand(item.id,false,item.id);
- if(item.id === 'code') {
- if(codeState) {
- rDiv.innerHTML = elm.value;
- elm.style.display = 'none';
- rDiv.style.display = 'block';
- rDiv.focus();
- }else{
- elm.value = formatCode(rDiv.innerHTML);
- elm.style.display = 'block';
- elm.focus();
- rDiv.style.display = 'none';
- }
- codeState = !codeState;
- item.title = ['代码模式','常规模式'][codeState * 1];
- set_btnState();
- }
- if(item.id === 'edlist') {
- orderlist.onchange = () => document.execCommand(orderlist.value,false,orderlist.value);
- orderlist.value = "0";
- }
- if(media_btns.includes(item.id)) {
- let hides = [[s4,s5,s6],[s1,s2,s3],[s3]];
- let shows = [[s1,s2,s3],[s4,s5,s6],[s1,s2,s4,s5]];
- let idx = {image: 0, audio: 1, video: 2};
- insertBox.style.left = item.offsetLeft + 'px';
- insertBox.style.top = ed_top.clientHeight + 'px';
- insertBox.style.display = 'block';
- insertIdx = idx[item.id];
- hideEle(hides[insertIdx],shows[insertIdx]);
- mtitle.innerText = '插入' + ['图片','音频','视频'][insertIdx];
- }
- elm.value = formatCode(rDiv.innerHTML);
- };
- });
- /* 插入媒体 */
- btnInsert.onclick = () => {
- rDiv.focus();
- let sWidth = oWidth ? ' wdth="' + oWidth.value + '"': '',
- sHeight = oHeight ? ' height="' + oWidth.value + '"': '',
- sAuto = oAuto.checked ? ' autoplay="autoplay"' : '',
- sLoop = oLoop.checked ? ' loop="loop"' : '',
- sCtrl = oCtrl.checked ? ' controls="controls"' : '';
- let htmls = [
- `<img src="${oSrc.value}"${sWidth}${sHeight} alt="" title="${oTitle.value}" />`,
- `<audio src="${oSrc.value}"${sCtrl}${sAuto}${sLoop}></audio>`,
- `<video src="${oSrc.value}"${sCtrl}${sWidth}${sHeight}${sAuto}${sLoop}></video>`
- ];
- if(oSrc.value) document.execCommand('inserthtml',false,htmls[insertIdx]);
- insertBox.style.display = 'none';
- };
- /* 前景色&背景色 */
- colors.forEach((item,key) => {
- if(!codeState) item.oninput = () => document.execCommand(item.id,false,item.value);
- });
- /* 编辑时同步 */
- rDiv.oninput = () => elm.value = rDiv.innerHTML;
- /* 收起媒体box */
- rDiv.onfocus = elm.onfocus = () => insertBox.style.display = 'none';
- })();
复制代码
【说明】
一口气写成的初稿,也许有许多缺陷与错误,测试尚未发现不能运行。
|
评分
-
| 参与人数 1 | 威望 +50 |
金钱 +100 |
经验 +50 |
收起
理由
|
红影
| + 50 |
+ 100 |
+ 50 |
赞一个! |
查看全部评分
|