原生js+css模仿word office文档在线编辑与导出docx、pdf文件代码
代码语言:html
所属分类:其他
代码描述:原生js+css模仿word office文档在线编辑与导出docx、pdf文件代码
代码标签: 原生 js css 模仿 word office 文档 在线 编辑 导出 docx pdf 文件 代
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>在线Word编辑器</title>
<!-- 引入必要的库 -->
<link type="text/css" rel="stylesheet" href="//repo.bfw.wiki/bfwrepo/css/all.6.4.0.css">
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/jspdf.umd.min.js"></script>
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/html2canvas.1.4.1.js"></script>
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/FileSaver.2.0.5.js"></script>
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/docx.iife.min.js"></script>
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/html-docx.min.js"></script>
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
font-family: 'Segoe UI', 'Microsoft YaHei', sans-serif;
background: #f0f0f0;
height: 100vh;
display: flex;
flex-direction: column;
}
/* 顶部标题栏 */
.title-bar {
background: #2b579a;
color: white;
padding: 5px 10px;
display: flex;
align-items: center;
font-size: 14px;
}
.title-bar i {
margin-right: 10px;
}
/* 菜单栏 */
.menu-bar {
background: #f3f3f3;
border-bottom: 1px solid #d1d1d1;
display: flex;
padding: 0 10px;
}
.menu-item {
padding: 8px 15px;
cursor: pointer;
color: #333;
font-size: 14px;
position: relative;
transition: background 0.3s;
}
.menu-item:hover {
background: #e1e1e1;
}
/* 工具栏容器 */
.toolbar-container {
background: white;
border-bottom: 1px solid #d1d1d1;
}
/* 功能区选项卡 */
.ribbon-tabs {
display: flex;
background: white;
border-bottom: 1px solid #d1d1d1;
}
.ribbon-tab {
padding: 8px 20px;
cursor: pointer;
font-size: 14px;
border: 1px solid transparent;
margin-right: 2px;
transition: all 0.3s;
}
.ribbon-tab:hover {
background: #f5f5f5;
}
.ribbon-tab.active {
background: #f3f3f3;
border: 1px solid #d1d1d1;
border-bottom: 1px solid #f3f3f3;
position: relative;
z-index: 1;
}
/* 工具栏 */
.toolbar {
background: #f3f3f3;
padding: 10px;
display: flex;
flex-wrap: wrap;
gap: 10px;
min-height: 100px;
align-items: flex-start;
}
.toolbar-group {
display: flex;
flex-direction: column;
border-right: 1px solid #d1d1d1;
padding-right: 10px;
margin-right: 10px;
}
.toolbar-group:last-child {
border-right: none;
}
.group-title {
font-size: 11px;
color: #666;
margin-top: 5px;
text-align: center;
}
.toolbar-buttons {
display: flex;
flex-wrap: wrap;
gap: 5px;
margin-bottom: 5px;
}
.toolbar-btn {
background: white;
border: 1px solid transparent;
padding: 5px 8px;
cursor: pointer;
font-size: 14px;
border-radius: 3px;
transition: all 0.2s;
display: flex;
align-items: center;
justify-content: center;
min-width: 35px;
height: 30px;
}
.toolbar-btn:hover {
background: #e1e1e1;
border-color: #b1b1b1;
}
.toolbar-btn.active {
background: #d1e9ff;
border-color: #0078d4;
}
.toolbar-btn i {
font-size: 16px;
}
.toolbar-separator {
width: 1px;
height: 30px;
background: #d1d1d1;
margin: 0 5px;
}
/* 下拉选择框 */
select {
padding: 5px;
border: 1px solid #d1d1d1;
background: white;
cursor: pointer;
font-size: 13px;
height: 30px;
border-radius: 3px;
}
select:hover {
border-color: #0078d4;
}
/* 颜色选择器 */
input[type="color"] {
width: 35px;
height: 30px;
border: 1px solid #d1d1d1;
border-radius: 3px;
cursor: pointer;
}
/* 编辑器容器 */
.editor-container {
flex: 1;
background: #808080;
display: flex;
justify-content: center;
padding: 20px;
overflow-y: auto;
}
/* 纸张样式 */
.paper {
background: white;
width: 210mm;
min-height: 297mm;
padding: 25mm 20mm;
box-shadow: 0 0 10px rgba(0,0,0,0.3);
margin-bottom: 20px;
}
/* 编辑区域 */
#editor {
min-height: 247mm;
outline: none;
font-size: 12pt;
line-height: 1.5;
colo.........完整代码请登录后点击上方下载按钮下载查看
















网友评论0