前端新手历险记之在VUE项目中使用Ace编辑器(brace)和一些TypeScript知识点
作者:V君 发布于:2018-9-8 23:52 Saturday 分类:折腾手记
TL;DR
▉ 将Ace编辑器引入项目
1) $npm install brace
2) $npm install --save @types/ace
3) ts:import * as ace from 'brace';
4) ts:import 'brace/...";
▉ TypeScript类型转换,对于 var dom = this.$refs["editor-dom"] 有两种方式
1) ts:ace.edit(dom as HTMLElement);
2) ts:ace.edit(<HTMLElement>dom);//这种方式会使tsx编译器报错标签未关闭,但实际能用
▉ 在TypeScript类中声明可空属性
在标识符后面加感叹号否则必须在构造时初始化,例子:
ts:private editor!: ace.Editor;
虽然这次的收获不多,但还是花了不少时间查资料来弄懂,得好好扯一扯:
终于到了不用跑公司的周末,接下来可以继续学习前端构建了。
继续之前发表的博文话题,依然是在VUE脚手架创建的项目上搞事情。
一直都想自己实现一个博客系统,虽然已经确定要用markdown来作为文章主体承载方式。
但还需要一个可靠的在线文本编辑器,把“web code editor”喂狗之后第一个跳出来的就是ace。
那就选它吧,看看怎么导入项目中来。
一开始的时候由于不知道brace和ace的关系,就一个劲地想把ace导入项目
分别尝试安装了好几个有ace字眼的包到项目里然后试图导入,结果没有一个能行。
接下来转移目标,找找看有没有别人封装好的VUE组件,拿过来用岂不是爽歪歪,
然而并不爽,但发现众多VUE组件封装的ace编辑器都引用了brace而不是ace。
查了才知道ace太过完整,甚至需要服务端支持,就有了brace这个纯前段的ace,
如其名“browserify compatible version of the ace editor”。
明确了要导入的东西之后发现它作为一个npm包是一个js库,在TS中使用只能作为any,
需要引入类型描述文件,这里又绕了一大圈,因为上述原因对于ace字样的包不去看,
一个劲地想找brace类型描述文件,最后还是用上了最初发现的@types/ace包。
在将类型描述文件和npm包搭配着导入到项目中之前还以不同的错误姿势尝试了半天,
用各种摸不着头脑的关键字喂狗,最后总算是参考着github上的文档将类型引入。
至此ace编辑器总算可以呈现在浏览器中。
然而要使用ace的其它功能还得用不同的姿势导入其他定义。
这次历险到此结束 XD
blogger
Google Web Translator
热门日志
随机日志
最新日志
最新评论
- V君
@Quartz:(出现)... - Quartz
怎么不见人了呢... - V君
@Soar:DHCP 协议相... - V君
@Soar:当然是非... - Soar
@V君:谢谢 有空... - Soar
搞一个 1230v3+B85... - V君
@Soar:另外,也可... - V君
@Soar:iscsi服务端... - Soar
难怪这么卡,尤其... - Soar
clone了源码,提示...
分类
存档
- 2024年5月(1)
- 2023年7月(1)
- 2023年5月(1)
- 2022年11月(1)
- 2022年10月(1)
- 2022年9月(1)
- 2022年8月(1)
- 2022年7月(1)
- 2022年6月(1)
- 2022年5月(2)
- 2022年4月(1)
- 2022年3月(1)
- 2022年2月(1)
- 2022年1月(1)
- 2021年12月(1)
- 2021年11月(1)
- 2021年10月(1)
- 2021年9月(1)
- 2021年8月(1)
- 2021年7月(1)
- 2021年6月(1)
- 2021年5月(1)
- 2021年4月(1)
- 2021年3月(1)
- 2021年2月(1)
- 2021年1月(1)
- 2020年12月(1)
- 2020年11月(1)
- 2020年10月(2)
- 2020年9月(1)
- 2020年8月(1)
- 2020年7月(1)
- 2020年6月(1)
- 2020年5月(1)
- 2020年4月(2)
- 2020年3月(3)
- 2020年2月(1)
- 2020年1月(1)
- 2019年12月(1)
- 2019年11月(1)
- 2019年10月(1)
- 2019年9月(1)
- 2019年8月(2)
- 2019年7月(1)
- 2019年6月(1)
- 2019年5月(1)
- 2019年4月(1)
- 2019年3月(1)
- 2019年2月(1)
- 2019年1月(2)
- 2018年12月(2)
- 2018年11月(1)
- 2018年10月(3)
- 2018年9月(4)
- 2018年8月(6)
- 2018年7月(4)
- 2018年6月(1)
- 2018年5月(2)
- 2018年4月(2)
- 2018年3月(3)
- 2018年2月(1)
- 2018年1月(1)
- 2017年12月(1)
- 2017年10月(2)
- 2017年9月(1)
- 2017年8月(2)
- 2017年7月(1)
- 2017年6月(5)
- 2017年5月(2)
- 2017年4月(2)
- 2017年3月(3)
- 2017年2月(2)
- 2017年1月(2)
- 2016年12月(3)
- 2016年11月(2)
- 2016年10月(3)
- 2016年9月(4)
- 2016年8月(2)
- 2016年7月(4)
- 2016年6月(3)
- 2016年5月(1)
- 2016年4月(4)
- 2016年3月(3)
- 2016年2月(1)
- 2016年1月(5)
- 2015年12月(4)
- 2015年11月(5)
- 2015年10月(1)
- 2015年9月(6)
- 2015年8月(4)
- 2015年7月(1)
- 2015年6月(6)
- 2015年5月(3)
- 2015年4月(3)
- 2015年3月(2)
- 2015年2月(1)
- 2015年1月(3)
- 2014年12月(1)
- 2014年11月(1)
- 2014年10月(1)
- 2014年9月(3)
- 2014年8月(1)
- 2014年7月(1)
- 2014年6月(1)
- 2014年5月(3)
- 2014年4月(1)
- 2014年3月(1)
- 2014年2月(2)
- 2014年1月(1)
- 2013年12月(2)
- 2013年11月(2)
- 2013年10月(1)
- 2013年9月(3)
- 2013年8月(14)
- 2013年7月(7)
- 2013年4月(1)
- 2013年3月(4)
- 2013年2月(6)
- 2013年1月(6)
- 2012年12月(8)
- 2012年11月(6)
发表评论: