用html+javascript打造公文一键排版系统1:设计界面

简介: 用html+javascript打造公文一键排版系统1:设计界面

近日,有同事抱怨收到的文件没有按公文要求进行排版,不得不自已动手帮他们擦PP排版,感慨每天都在做这些无意义的事情,浪费生命!

于是打算用用html+javascript打造公文一键排版系统。

首先是设置界面,主要包括四个部分:

一、实时编辑区。

用<iframe>做一个所见即所得文本编辑框。

二、功能按钮。

暂时提供五个按钮,分别提供“清除格式”、“一键排版”、“显示源码”、设置字体“加粗/正常”和“斜体/正常”功能。

三、公文参数设置区。

公文要求一般是:

1.公文标题:一般用2号小标宋体字。

2.正文:一般用3号仿宋体字,编排于主送机关名称下一行,每个自然段左空二字,回行顶格。

正文中的标题分为四级,文中结构层次序数依次可以用“一、”“(一)”“1.”“(1)”标注;一般第一层用黑体字、第二层用楷体字加粗、第三层和第四层用仿宋体字标注。

3.行间距:一般是28磅。

因此,对于公文标题,提供字体选择框(ListBox, 默认值“方正小标宋简体”)、字号选择框(ListBox,默认值二号)、对齐方式选择框(ListBox,默认值居中对齐)。

对于一级标题,提供字体选择框(ListBox,默认值“黑体”)、字号(ListBox,默认值dg 号)。

对于二级标题,提供字体选择框(ListBox,默认值“楷体_GB2312”)、字号(ListBox,默认值三 号),加粗钩选框(checkbox,默认钩选)。

对于三级标题,提供加粗钩选框(checkbox,默认钩选)。

对于正文,提供了两个选项:行间距文本框(textbox,默认值28)、段落首行行首空格数文本框:(textbox,默认值2)。

四、调试信息区。

用<textarea>显示调试信息。

具体如下:

image.png

相应代码:

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>公文一键排版</title>
<meta name="author" content="purpleendurer" >
<meta name="description" content="公文一键排版">
<script type="text/javascript">
const aFontName = [
  "方正小标宋简体",//0
  "黑体",//1
  "微软雅黑",//2
  "仿宋_GB2312",//3
  "仿宋",//4
  "楷体_GB2312",//5
  "楷体",//6
  "宋体",//7
  "Arial",//8
  "Wingdings 2"//9
];

//sId:select control id, iDefSel:default selected
function showFontNameSel(sId, iDefSel)
{
  document.write('<select id="', sId, '" width="50">');
  for (var i = 0; i < aFontName.length; i++)
  {
    document.write('<option value="', aFontName[i], '"');
    document.write(i==iDefSel ? ' selected>' : '>');
    document.write(aFontName[i],'</option>');
  }
  document.write('</select>');
}
const aFontSize = [
  ['初号', 42],//0
  ['小初', 36],//1
  ['一号', 26],//2
  ['小一', 24],//3
  ['二号', 22],//4
  ['小二', 18],//5
  ['三号', 16],//6
  ['小三', 15],//7
  ['四号', 14],//8
  ['小四', 12],//9
  ['五号', 10.5], //10
  ['小五', 9],//11
  ['六号', 7.5],//12
  ['小六', 6.5],//13
  ['七号', 5.5],//14
  ['八号', 5]//15
];


//sId:select control id, iDefSel:default selected
function showFontSizeSel(sId, iDefSel)
{
  document.write('<select id="', sId, '">');
  for (var i = 0; i < aFontSize.length; i++)
  {
    document.write('<option value="',aFontSize[i][1], '"');
    document.write(i==iDefSel ? ' selected>' : '>');
    document.write(aFontSize[i][0],'</option>');
  }
  document.write('</select>');
}


const aAlign = [
  ["左对齐","left"],//0
  ["居中对齐","center"],//1
  ["右对齐","right"],//2
  ["两端分散对齐","justify"]//3
];


//sId:select control id, iDefSel:default selected
function showAlignSel(sId, iDefSel)
{
  document.write('<select id="', sId, '">');
  for (var i = 0; i < aAlign.length; i++)
  {
    document.write('<option value="',aAlign[i][1], '"');
    document.write(i==iDefSel ? ' selected>' : '>');
    document.write(aAlign[i][0],'</option>');
  }
  document.write('</select>');
}
</script>
</head>
<body>
<fieldset  style="width: 1100px;">
 <legend>实时编辑区</legend>
<!--
<iframe id="editor" width="600px" height="200px" style="border: solid 1px;" src="http://nyncj.hechi.gov.cn"></iframe>
//-->
<iframe id="editor" width="1200px" height="400px" style="border: solid 1px;"></iframe>
</fieldset>
<p>
  <input type="button" id="btnclearDocFmt" value="清除格式" onclick="clearDocFmt()" />
  <input type="button" id="btnsetDocFmt" value="一键排版" onclick="setDocFmt()" />
  <input type="button" id="btnShowSrc" value="显示源码" onclick="showSrc()" style="background:yellow; border-radius: 25px;" />
  <input type="button" id="btnB" value="B" title="加粗/正常"  style="font-weight:bolder" onclick="execCmd('bold',false,null)" />
  <input type="button" id="btnItalic" value="I" title="斜体/正常"  style="font-weight:bolder;font-style:italic" onclick="execCmd('italic',false,null)" />
</p>
<fieldset style="width: 1200px;">
  <legend>参数设置</legend>
  <p>文件标题:
  <script>
    showFontNameSel("selDocTitleFontName", 0);
    document.write(' ');
    showFontSizeSel("selDocTitleFontSize", 4);
    document.write(' ');
    showAlignSel("selDocTitleAlign", 1);
  </script>
  <p>一级标题:
  <script>
    showFontNameSel("selPrimaryTitleFontName", 1);
    document.write(' ');
    showFontSizeSel("selPrimaryTitleFontSize", 6);
  </script>
  </p>
  <p>二级标题:
  <script>
    showFontNameSel("selSecondaryTitleFontName", 5);
    document.write(' ');
    showFontSizeSel("selSecondaryTitleFontSize", 6);
  </script>
    <input type="checkbox" checked id="cbSecondaryTitleString">粗体
  </p>
  <p>三级标题:
    <input type="checkbox" checked id="cbThirdTitleString">粗体
  </p>
  <p>行距(行间距):<input type="text" id="tbRowSp" value="28" size="2"><!--  row spacing//-->  段落首行行首空格数:<input type="text" id="tbLeadSpNum" value="2" size="2">
  </P>
 </fieldset>
<p>调试信息</p>
<textarea id="taDbg" style="width: 1225px; height: 200px">调试信息</textarea>
<script type="text/javascript">
const edRich = document.getElementById("editor");
const taDbg = document.getElementById("taDbg");
const btnShowSrc =  document.getElementById("btnShowSrc");
//一级标题字号 font name
var pt1fn = document.getElementById('selPrimaryTitleFontName').value;
//一级标题字号 font size
var pt1fs =  document.getElementById('selPrimaryTitleFontSize').value;
//alert(fs);
//行距 row spacing
 var rs  =  document.getElementById('tbRowSp').value;
//首行行首空格数
 var sn  =  document.getElementById('tbLeadSpNum').value;
// (iframe.contentDocument||iframe.contentWindow.document).body.innerHTML
var edRichDoc;
var edRichBody;
if (typeof(edRich) !="undefined")
 {
  edRichDoc = edRich.contentWindow.document;
  edRichDoc.designMode = "on";
  edRichDoc.contentEditable = true;
  edRichBody =  edRichDoc.body;
  edRichBody.innerHTML = '<a href=
}
else
{
  window.alert("undefined");
}
</script>
</body>
</html>
目录
打赏
0
1
0
0
57
分享
相关文章
单页图床HTML源码+本地API接口图床系统源码
图床系统是一种用于存储和管理图片文件的在线服务。它允许用户上传图片文件,并生成相应的图片链接,从而方便用户在网页、社交媒体或其他平台上分享图片。
69 2
单页图床HTML源码+本地API接口图床系统源码
【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
173 13
【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
126 14
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
126 11
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
138 13
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
|
2月前
|
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
70 1
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
173 21
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
82 14
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
3月前
html+js+css实现的建筑方块立体数字时钟源码
html+js+css实现的建筑方块立体数字时钟源码
125 33
基于 Node.js Socket 算法搭建局域网屏幕监控系统
在数字化办公环境中,局域网屏幕监控系统至关重要。基于Node.js的Socket算法实现高效、稳定的实时屏幕数据传输,助力企业保障信息安全、监督工作状态和远程技术支持。通过Socket建立监控端与被监控端的数据桥梁,确保实时画面呈现。实际部署需合理分配带宽并加密传输,确保信息安全。企业在使用时应权衡利弊,遵循法规,保障员工权益。
92 7
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等