mirror of
https://gitee.com/was666/as-editor.git
synced 2025-02-23 18:42:55 +08:00
feat: 新增预览功能
This commit is contained in:
parent
3d88c63345
commit
d49b223059
11
README.md
11
README.md
@ -4,17 +4,16 @@
|
|||||||
|
|
||||||
基于 vue 可视化拖拽编辑,页面生成工具。提升前端开发效率,可集成至移动端项目作为通过定义 JSON 直接生成 UI 界面。
|
基于 vue 可视化拖拽编辑,页面生成工具。提升前端开发效率,可集成至移动端项目作为通过定义 JSON 直接生成 UI 界面。
|
||||||
|
|
||||||
|
|
||||||
文档地址:[https://was666.gitee.io/as-editor-doc](https://was666.gitee.io/as-editor-doc)
|
文档地址:[https://was666.gitee.io/as-editor-doc](https://was666.gitee.io/as-editor-doc)
|
||||||
|
|
||||||
在线体验:[http://was666.gitee.io/as-editor](http://was666.gitee.io/as-editor)
|
在线体验:[http://was666.gitee.io/as-editor](http://was666.gitee.io/as-editor)
|
||||||
|
|
||||||
#### 安装教程
|
#### 安装教程
|
||||||
|
|
||||||
1. npm install (安装 node_modules 模块)
|
1. npm install (安装 node_modules 模块)
|
||||||
2. npm run serve (运行)
|
2. npm run serve (运行)
|
||||||
3. npm run build (打包)
|
3. npm run build (打包)
|
||||||
4. npm update (用于更新包到基于规范范围的最新版本)
|
4. npm update (用于更新包到基于规范范围的最新版本)
|
||||||
|
|
||||||
#### 使用说明
|
#### 使用说明
|
||||||
|
|
||||||
@ -24,12 +23,12 @@
|
|||||||
data:image/s3,"s3://crabby-images/42dc9/42dc95420001cc8dd57c240fe4e9bf3c12535ad1" alt="步骤2"
|
data:image/s3,"s3://crabby-images/42dc9/42dc95420001cc8dd57c240fe4e9bf3c12535ad1" alt="步骤2"
|
||||||
data:image/s3,"s3://crabby-images/c77cb/c77cbd364a9a564f757049dffe1976995e1b1a60" alt="步骤3"
|
data:image/s3,"s3://crabby-images/c77cb/c77cbd364a9a564f757049dffe1976995e1b1a60" alt="步骤3"
|
||||||
data:image/s3,"s3://crabby-images/c5448/c544811f9a64263eb3385c3168beadbc85df00e7" alt="步骤4"
|
data:image/s3,"s3://crabby-images/c5448/c544811f9a64263eb3385c3168beadbc85df00e7" alt="步骤4"
|
||||||
data:image/s3,"s3://crabby-images/8bed6/8bed652fd7e3ba123268aee0759833034f0beb80" alt="步骤5"
|
data:image/s3,"s3://crabby-images/e447f/e447fade24628cb53f88f90d74606dec77bcf916" alt="步骤5"
|
||||||
data:image/s3,"s3://crabby-images/8a728/8a728ef946c81682bc5475013905200d422ccef9" alt="步骤6"
|
data:image/s3,"s3://crabby-images/0d738/0d738b9617fadeb07e32e655fef3d5998ba943f9" alt="步骤6"
|
||||||
|
|
||||||
##### 自定义组件可以看:
|
##### 自定义组件可以看:
|
||||||
|
|
||||||
```js
|
```
|
||||||
src / layout / home / index.vue // 编辑页面文件
|
src / layout / home / index.vue // 编辑页面文件
|
||||||
src / components / sliderassembly / index.vue // 左侧组件大全文件
|
src / components / sliderassembly / index.vue // 左侧组件大全文件
|
||||||
src / components / componentscom // 左侧组件目录
|
src / components / componentscom // 左侧组件目录
|
||||||
|
92
src/components/headerTop/index.vue
Normal file
92
src/components/headerTop/index.vue
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
<template>
|
||||||
|
<div
|
||||||
|
class="headerTop"
|
||||||
|
:style="{
|
||||||
|
height: pageSetup.titleHeight + 'px',
|
||||||
|
}"
|
||||||
|
>
|
||||||
|
<!-- 左半部分 -->
|
||||||
|
<div class="lef" v-show="pageSetup.isBack">
|
||||||
|
<van-icon name="arrow-left" />
|
||||||
|
</div>
|
||||||
|
<!-- 标题 -->
|
||||||
|
<div
|
||||||
|
class="header-title"
|
||||||
|
:style="{
|
||||||
|
height: pageSetup.titleHeight + 'px',
|
||||||
|
'line-height': pageSetup.titleHeight + 'px',
|
||||||
|
}"
|
||||||
|
>
|
||||||
|
{{ pageSetup.name }}
|
||||||
|
</div>
|
||||||
|
<!-- 右半部分 -->
|
||||||
|
<div class="rig" v-show="pageSetup.isPerson">
|
||||||
|
<span>个人中心</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'headerTop',
|
||||||
|
props: {
|
||||||
|
pageSetup: Object,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="less" scoped>
|
||||||
|
.headerTop {
|
||||||
|
height: 35px;
|
||||||
|
width: 100%;
|
||||||
|
background: #fff;
|
||||||
|
display: flex;
|
||||||
|
padding: 0 5px;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items: center;
|
||||||
|
cursor: pointer;
|
||||||
|
border-bottom: 1px solid #f7f8fa;
|
||||||
|
position: relative;
|
||||||
|
/* 左边 */
|
||||||
|
.lef {
|
||||||
|
position: absolute;
|
||||||
|
left: 18px;
|
||||||
|
top: 50%;
|
||||||
|
transform: translateY(-50%);
|
||||||
|
/* 图标 */
|
||||||
|
span {
|
||||||
|
color: #000;
|
||||||
|
font-weight: 400;
|
||||||
|
font-size: 12px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.header-title {
|
||||||
|
width: 100%;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 14px;
|
||||||
|
line-height: 35px;
|
||||||
|
color: #333333;
|
||||||
|
}
|
||||||
|
/* 右边 */
|
||||||
|
.rig {
|
||||||
|
// display: flex;
|
||||||
|
// align-items: center;
|
||||||
|
// height: 100%;
|
||||||
|
position: absolute;
|
||||||
|
right: 18px;
|
||||||
|
top: 50%;
|
||||||
|
transform: translateY(-50%);
|
||||||
|
/* 搜索图标 */
|
||||||
|
i {
|
||||||
|
font-size: 18px;
|
||||||
|
margin: 0 7px 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 文字 */
|
||||||
|
span {
|
||||||
|
margin: 0 7px;
|
||||||
|
font-size: 12px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
@ -1,18 +1,14 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="phoneBottom">
|
<div class="phoneBottom"></div>
|
||||||
<p class="ft-links" v-show="datas.isShowBootom">
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
export default {
|
export default {
|
||||||
name: 'phoneBottom',
|
name: 'phoneBottom',
|
||||||
props:['datas'],
|
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped lang="less">
|
<style lang="less" scoped>
|
||||||
.phoneBottom {
|
.phoneBottom {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
@ -20,32 +16,5 @@ export default {
|
|||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
padding-top: 30px;
|
padding-top: 30px;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
.ft-links {
|
|
||||||
text-align: center;
|
|
||||||
padding: 0px 15px 10px;
|
|
||||||
span {
|
|
||||||
padding: 0 6px;
|
|
||||||
color: #666;
|
|
||||||
font-size: 12px;
|
|
||||||
border-right: 1px solid #e5e5e5;
|
|
||||||
&:last-of-type {
|
|
||||||
border-right: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.yinjia {
|
|
||||||
color: #bfbfc3;
|
|
||||||
text-align: center;
|
|
||||||
font-size: 11px;
|
|
||||||
display: flex;
|
|
||||||
justify-content: center;
|
|
||||||
align-items: center;
|
|
||||||
.logo {
|
|
||||||
width: 15px;
|
|
||||||
height: 15px;
|
|
||||||
margin-right: 5px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
47
src/components/realTimeView/index.vue
Normal file
47
src/components/realTimeView/index.vue
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
<template>
|
||||||
|
<div class="RealTimeView">
|
||||||
|
<el-dialog :visible.sync="datas.show" width="414px" top="8vh">
|
||||||
|
<img src="@/assets/images/phoneTop.png" style="width: 375px" />
|
||||||
|
<iframe
|
||||||
|
v-if="datas.show"
|
||||||
|
ref="iframe"
|
||||||
|
class="screen"
|
||||||
|
:scrolling="false"
|
||||||
|
:src="'http://was666.gitee.io/as-editor-h5/#/?type=iframe'"
|
||||||
|
@load="load"
|
||||||
|
></iframe>
|
||||||
|
</el-dialog>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'RealTimeView',
|
||||||
|
props: {
|
||||||
|
datas: {
|
||||||
|
show: false,
|
||||||
|
},
|
||||||
|
val:Object
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
load() {
|
||||||
|
this.$refs["iframe"].contentWindow.postMessage(this.val, "*");
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="less" scoped>
|
||||||
|
.RealTimeView {
|
||||||
|
.screen {
|
||||||
|
width: 375px /*no*/;
|
||||||
|
height: 667px /*no*/;
|
||||||
|
border: 0;
|
||||||
|
|
||||||
|
// 隐藏滚动条
|
||||||
|
&::-webkit-scrollbar {
|
||||||
|
display: none; /* Chrome Safari */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
@ -17,10 +17,18 @@
|
|||||||
<el-button @click="reloads" type="danger"
|
<el-button @click="reloads" type="danger"
|
||||||
><i class="el-icon-delete-solid el-icon--left"></i>重置</el-button
|
><i class="el-icon-delete-solid el-icon--left"></i>重置</el-button
|
||||||
>
|
>
|
||||||
|
<el-button @click="realTimeView.show = true">预览</el-button>
|
||||||
<el-button @click="catJson">查看JSON </el-button>
|
<el-button @click="catJson">查看JSON </el-button>
|
||||||
<el-button @click="$refs.file.click()" >导入JSON </el-button>
|
<el-button @click="$refs.file.click()">导入JSON </el-button>
|
||||||
<el-button @click="exportJSON">导出JSON </el-button>
|
<el-button @click="exportJSON">导出JSON </el-button>
|
||||||
<input type="file" ref="file" id="file" accept=".json" @change="importJSON" style="display: none;" />
|
<input
|
||||||
|
type="file"
|
||||||
|
ref="file"
|
||||||
|
id="file"
|
||||||
|
accept=".json"
|
||||||
|
@change="importJSON"
|
||||||
|
style="display: none"
|
||||||
|
/>
|
||||||
<!-- <el-button @click="Preservation"
|
<!-- <el-button @click="Preservation"
|
||||||
><i class="el-icon-s-claim el-icon--left"></i>保存</el-button
|
><i class="el-icon-s-claim el-icon--left"></i>保存</el-button
|
||||||
> -->
|
> -->
|
||||||
@ -35,36 +43,10 @@
|
|||||||
<!-- 手机 -->
|
<!-- 手机 -->
|
||||||
<div class="phone">
|
<div class="phone">
|
||||||
<section class="phoneAll" ref="imageTofile" id="imageTofile">
|
<section class="phoneAll" ref="imageTofile" id="imageTofile">
|
||||||
<!-- 导航栏 -->
|
|
||||||
<img src="@/assets/images/phoneTop.png" alt="" class="statusBar" />
|
<img src="@/assets/images/phoneTop.png" alt="" class="statusBar" />
|
||||||
|
|
||||||
<!-- 标题 -->
|
<!-- 头部导航 -->
|
||||||
<div
|
<headerTop :pageSetup="pageSetup" @click.native="headTop" />
|
||||||
class="headerTop"
|
|
||||||
:style="{
|
|
||||||
height: pageSetup.titleHeight + 'px',
|
|
||||||
}"
|
|
||||||
@click="headTop"
|
|
||||||
>
|
|
||||||
<!-- 左半部分 -->
|
|
||||||
<div class="lef" v-show="pageSetup.isBack">
|
|
||||||
<van-icon name="arrow-left" />
|
|
||||||
</div>
|
|
||||||
<!-- 标题 -->
|
|
||||||
<div
|
|
||||||
class="header-title"
|
|
||||||
:style="{
|
|
||||||
height: pageSetup.titleHeight + 'px',
|
|
||||||
'line-height': pageSetup.titleHeight + 'px',
|
|
||||||
}"
|
|
||||||
>
|
|
||||||
{{ pageSetup.name }}
|
|
||||||
</div>
|
|
||||||
<!-- 右半部分 -->
|
|
||||||
<div class="rig" v-show="pageSetup.isPerson">
|
|
||||||
<span>个人中心</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- 主体内容 -->
|
<!-- 主体内容 -->
|
||||||
<section
|
<section
|
||||||
@ -110,7 +92,7 @@
|
|||||||
<div class="phoneSize">iPhone 8手机高度</div>
|
<div class="phoneSize">iPhone 8手机高度</div>
|
||||||
|
|
||||||
<!-- 底部 -->
|
<!-- 底部 -->
|
||||||
<phoneBottom :datas="pageSetup.bottomLogo" />
|
<phoneBottom />
|
||||||
</section>
|
</section>
|
||||||
<!-- 底部 -->
|
<!-- 底部 -->
|
||||||
</div>
|
</div>
|
||||||
@ -144,18 +126,24 @@
|
|||||||
<div class="decorateAll">
|
<div class="decorateAll">
|
||||||
<!-- 页面设置 -->
|
<!-- 页面设置 -->
|
||||||
<transition name="decorateAnima">
|
<transition name="decorateAnima">
|
||||||
<!-- 路由缓存 -->
|
<!-- 动态组件 -->
|
||||||
<keep-alive exclude="richtextstyle">
|
<component
|
||||||
<!-- 动态组件 -->
|
:is="rightcom"
|
||||||
<component
|
:datas="currentproperties"
|
||||||
:is="rightcom"
|
@componenmanagement="componenmanagement"
|
||||||
:datas="currentproperties"
|
/>
|
||||||
@componenmanagement="componenmanagement"
|
|
||||||
/>
|
|
||||||
</keep-alive>
|
|
||||||
</transition>
|
</transition>
|
||||||
</div>
|
</div>
|
||||||
</section>
|
</section>
|
||||||
|
<realTimeView
|
||||||
|
:datas="realTimeView"
|
||||||
|
:val="{
|
||||||
|
id,
|
||||||
|
name: pageSetup.name,
|
||||||
|
templateJson: JSON.stringify(pageSetup),
|
||||||
|
component: JSON.stringify(pageComponents),
|
||||||
|
}"
|
||||||
|
/>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -163,7 +151,9 @@
|
|||||||
import utils from 'utils/index' // 方法
|
import utils from 'utils/index' // 方法
|
||||||
import componentProperties from '@/utils/componentProperties' // 组件数据
|
import componentProperties from '@/utils/componentProperties' // 组件数据
|
||||||
import sliderassembly from 'components/sliderassembly' // 左侧组件大全
|
import sliderassembly from 'components/sliderassembly' // 左侧组件大全
|
||||||
|
import headerTop from 'components/headerTop' // 手机底部
|
||||||
import phoneBottom from 'components/phoneBottom' // 手机底部
|
import phoneBottom from 'components/phoneBottom' // 手机底部
|
||||||
|
import realTimeView from 'components/realTimeView' // 预览组件
|
||||||
|
|
||||||
import html2canvas from 'html2canvas' // 生成图片
|
import html2canvas from 'html2canvas' // 生成图片
|
||||||
import FileSaver from 'file-saver' // 导入or导出JSON
|
import FileSaver from 'file-saver' // 导入or导出JSON
|
||||||
@ -228,6 +218,9 @@ export default {
|
|||||||
inject: ['reload'],
|
inject: ['reload'],
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
realTimeView: {
|
||||||
|
show: false, // 是否显示预览
|
||||||
|
},
|
||||||
id: null, //当前页面
|
id: null, //当前页面
|
||||||
deleShow: true, //删除标签显示
|
deleShow: true, //删除标签显示
|
||||||
index: '', //当前选中的index
|
index: '', //当前选中的index
|
||||||
@ -237,15 +230,11 @@ export default {
|
|||||||
// 页面设置属性
|
// 页面设置属性
|
||||||
name: '页面标题', //页面名称
|
name: '页面标题', //页面名称
|
||||||
details: '', //页面描述
|
details: '', //页面描述
|
||||||
bgColor: 'rgba(249, 249, 249, 10)', //背景颜色
|
|
||||||
bottomLogo: {
|
|
||||||
isShowBootom: false,
|
|
||||||
botLogo: '',
|
|
||||||
}, // 底部logo
|
|
||||||
isPerson: false, // 是否显示个人中心
|
isPerson: false, // 是否显示个人中心
|
||||||
isBack: true, // 是否返回按钮
|
isBack: true, // 是否返回按钮
|
||||||
titleHeight: 35,
|
titleHeight: 35, // 高度
|
||||||
bgImg: '',
|
bgColor: 'rgba(249, 249, 249, 10)', //背景颜色
|
||||||
|
bgImg: '', // 背景图片
|
||||||
},
|
},
|
||||||
pageComponents: [], //页面组件
|
pageComponents: [], //页面组件
|
||||||
offsetY: 0, //记录上一次距离父元素高度
|
offsetY: 0, //记录上一次距离父元素高度
|
||||||
@ -255,8 +244,8 @@ export default {
|
|||||||
},
|
},
|
||||||
|
|
||||||
mounted() {
|
mounted() {
|
||||||
this.pageSetup.name = '页面标题'
|
this.pageSetup.name = '页面标题'
|
||||||
this.currentproperties = this.pageSetup
|
this.currentproperties = this.pageSetup
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
@ -282,15 +271,6 @@ export default {
|
|||||||
callback: () => {},
|
callback: () => {},
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
console.log(
|
|
||||||
{
|
|
||||||
id: this.id,
|
|
||||||
name: this.pageSetup.name,
|
|
||||||
templateJson: this.pageSetup,
|
|
||||||
component: this.pageComponents,
|
|
||||||
},
|
|
||||||
'----------------查看JSON'
|
|
||||||
)
|
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
* 保存
|
* 保存
|
||||||
@ -332,7 +312,7 @@ export default {
|
|||||||
let url = canvas.toDataURL('image/png')
|
let url = canvas.toDataURL('image/png')
|
||||||
const formData = new FormData()
|
const formData = new FormData()
|
||||||
formData.append('base64File', url)
|
formData.append('base64File', url)
|
||||||
console.log(formData,'--------------页面图片formData')
|
console.log(formData, '--------------页面图片formData')
|
||||||
loading.close()
|
loading.close()
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
@ -634,7 +614,7 @@ export default {
|
|||||||
// this.result为读取到的json字符串,需转成json对象
|
// this.result为读取到的json字符串,需转成json对象
|
||||||
let ImportJSON = JSON.parse(this.result)
|
let ImportJSON = JSON.parse(this.result)
|
||||||
// 检测是否导入成功
|
// 检测是否导入成功
|
||||||
console.log(ImportJSON,'-----------------导入成功')
|
console.log(ImportJSON, '-----------------导入成功')
|
||||||
// 导入JSON数据
|
// 导入JSON数据
|
||||||
_this.id = ImportJSON.id
|
_this.id = ImportJSON.id
|
||||||
_this.pageSetup = JSON.parse(ImportJSON.templateJson)
|
_this.pageSetup = JSON.parse(ImportJSON.templateJson)
|
||||||
@ -645,7 +625,6 @@ export default {
|
|||||||
|
|
||||||
watch: {
|
watch: {
|
||||||
/* 监听右侧属性设置切换 */
|
/* 监听右侧属性设置切换 */
|
||||||
|
|
||||||
rightcom(newval) {
|
rightcom(newval) {
|
||||||
if (newval === 'decorate') {
|
if (newval === 'decorate') {
|
||||||
utils.forEach(this.pageComponents, (res) => {
|
utils.forEach(this.pageComponents, (res) => {
|
||||||
@ -667,6 +646,8 @@ export default {
|
|||||||
},
|
},
|
||||||
|
|
||||||
components: {
|
components: {
|
||||||
|
headerTop,
|
||||||
|
realTimeView,
|
||||||
decorate,
|
decorate,
|
||||||
componenmanagement,
|
componenmanagement,
|
||||||
phoneBottom,
|
phoneBottom,
|
||||||
@ -851,61 +832,6 @@ export default {
|
|||||||
line-height: 21px;
|
line-height: 21px;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 头部 */
|
|
||||||
.headerTop {
|
|
||||||
height: 35px;
|
|
||||||
width: 100%;
|
|
||||||
background: #fff;
|
|
||||||
display: flex;
|
|
||||||
padding: 0 5px;
|
|
||||||
justify-content: space-between;
|
|
||||||
align-items: center;
|
|
||||||
cursor: pointer;
|
|
||||||
border-bottom: 1px solid #f7f8fa;
|
|
||||||
position: relative;
|
|
||||||
/* 左边 */
|
|
||||||
.lef {
|
|
||||||
position: absolute;
|
|
||||||
left: 18px;
|
|
||||||
top: 50%;
|
|
||||||
transform: translateY(-50%);
|
|
||||||
/* 图标 */
|
|
||||||
span {
|
|
||||||
color: #000;
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 12px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.header-title {
|
|
||||||
width: 100%;
|
|
||||||
text-align: center;
|
|
||||||
font-size: 14px;
|
|
||||||
line-height: 35px;
|
|
||||||
color: #333333;
|
|
||||||
}
|
|
||||||
/* 右边 */
|
|
||||||
.rig {
|
|
||||||
// display: flex;
|
|
||||||
// align-items: center;
|
|
||||||
// height: 100%;
|
|
||||||
position: absolute;
|
|
||||||
right: 18px;
|
|
||||||
top: 50%;
|
|
||||||
transform: translateY(-50%);
|
|
||||||
/* 搜索图标 */
|
|
||||||
i {
|
|
||||||
font-size: 18px;
|
|
||||||
margin: 0 7px 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 文字 */
|
|
||||||
span {
|
|
||||||
margin: 0 7px;
|
|
||||||
font-size: 12px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 状态栏 */
|
/* 状态栏 */
|
||||||
.statusBar {
|
.statusBar {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
Loading…
Reference in New Issue
Block a user