自己动手制作更好用的markdown编辑器-03
上一篇我们实现了文件的新建,保存,打开功能.
在这篇里我们将实现以下功能:
- 系统模块,包含一些软件的设置和存储功能
- 记录上次打开的文件
- 编辑器样式选择
系统模块
跟之前的studio
模块类似,我们在modules模块下增加system
目录.
比studio多了model.js
文件,用来实现系统模块的一些功能.
在app.js
里加载system
模块
1 |
angular.module('hmd', ['ui.router','hmd.directives','hmd.studio','hmd.system']) |
路由、导航栏angular.js
用得不熟,导航栏的状态根据route来切换一直不知道怎么实现比较优雅.
我直接在app.js
里增加了一个导航栏切换的方法,每个route的onEnter事件里自行调用这个方法.
1 |
//TODO:更优雅的导航栏切换逻辑 |
system/route.js
1 |
hmd.system.config(function ($stateProvider, $urlRouterProvider) { |
studio/route.js
1 |
... |
然后在index.html
里配置好导航
1 |
... |
导航栏最终效果:
记录上次打开的文件
每次打开文件都会被记住,下次重新启动程序时将默认打开最后一次打开的文件.
system设置的读取和保存
我们先在system/model.js
实现保存和读取设置的功能.
1 |
var util = require('./helpers/util'), |
system
实现了get
和save
方法,所有的设置都存储在一个简单的对象里,代码里并没有对这个对象做缓存,每次都是从文件里读取,因为这简单的文件还远达不到影响读取速度的情况.
然后我们修改editor
的setFile
方法,暴露setFiled
事件给外部使用.
1 |
//设置当前文件 |
最后修改studio/directives.js
的hmdEditor
,实现这个功能.
1 |
studio.directive('hmdEditor', function () { |
编辑器样式选择
样式修改表单
样式文件在目录app/lib/codemirror/theme.
目录里每一个样式文件代表一种编辑器样式,还记得当初实现editor
的init
时,样式已经是通过配置传入的.
1 |
... |
现在我们只要把theme参数存储到配置里,并提供给用户修改就可以.
在system/model.js
里的默认配置增加一个theme
字段.
1 |
... |
修改system/views/system.html
模版,增加样式表单
1 |
<div class="content studio-wrap"> |
这里的select控件我们先写了3个选项.现在先实现这个修改样式的功能,等完成这个功能后再把选项列表做成自动生成.
对应的system/controllers.js
(开发了3天了,终于第一次用到controller了)
1 |
system.controller('system', function ($scope) { |
controller
里读取system的数据,并赋值给$scope.systemSetting
,用于表单的数据绑定.由于angular
实现了数据的双向绑定,因此用户编辑表单时,绑定的数据也会跟着更新.这样我们的save
方法里只要将表单绑定的数据保存回system即可.
button按钮绑定save方法ng-click="save(systemSetting)"
.
这里可以稍微感受到angular
让我们节省了很多工作量.
自动生成select列表
修改controller
1 |
var system = hmd.system, |
从theme
目录里读取所有样式列表,生成键值对,然后赋值给$scope.themes
修改视图模版:
1 |
<select name="theme" ng-model="systemSetting.theme" ng-options="k as v for (k, v) in themes"> |
ng-options="k as v for (k, v) in themes"
是angular的绑定语法
这样我们就实现了样式列表的自动读取,用户如果想自定义样式,只要在app/lib/codemirror/theme
目录新增一个样式文件,并写上自己的样式就可以在系统设置里选择自定义的样式了.
总结
今天实现了记忆最后一次打开的文件以及样式选择的功能,并且第一次使用了angular
的controller
,感受到了angular
双向数据绑定的强大.
我们的程序又更好用一些了(但是随着界面变多,又更丑了,太为难了).
最终效果截图
附件
最新文章
- struts2 配置拦截器
- Sping Environment为Null的原因和解决方法
- leetcode56. Merge Intervals
- 在View页面,使用@if(){ }输出判断正确的内容
- 从Ecipse中导出程序至apk
- [原]bochs+dos6.22汇编环境
- tableview cell添加3D动画
- Java 后台创建word 文档
- 基于Grafana的Repeate Panel快速定义面板
- Python接口测试,Requests模块讲解:GET、POST、Cookies、Session等
- 解决Editor.md通过代码块原样输出Emoji被强制解析问题
- redi应用-延时队列
- ubuntu 终端作死体验
- C#中的参数和调用方式(可选参数、具名参数、可空参数)
- HDU1285确定比赛名次
- 什么是fortran语言之fortran语言入门
- 关于ios发布AppStore验证UUID不过的问题
- scrapy定制爬虫-爬取javascript——乾颐堂
- Centos 7 修改默认的运行级别
- oradebug 的学习 一