当前位置:网站首页>Basic usage of Vue codemirror: search function, code folding function, get editor value and verify in time
Basic usage of Vue codemirror: search function, code folding function, get editor value and verify in time
2020-11-06 20:42:00 【Tell me Zhan to hide】
Yesterday, we realized some codemirror: Basic edit code function 、 Insert variable function 、codemirror Syntax verification function 、 Code formatting ( Because it's mainly json data , So there is no reference to other components for the time being , If necessary, suggest quoting js-beautify, Because we found that codemirror In the new version autoFormatRange Method ), If you want to know more , Please refer to 《 Teach you to understand easily vue-codemirror The basic usage of : The main implementation of code editing 、 Verification tips 、 Code formatting 》, Today continues with yesterday's function code , Mainly share vue-codemirror Realize search function 、 Code folding function 、 Get editor value and verify function in time .
1. vue-codemirror Search function
1.1 On the basis of the original need to introduce the required resources
import 'codemirror/addon/scroll/annotatescrollbar.js'
import 'codemirror/addon/search/matchesonscrollbar.js'
import 'codemirror/addon/search/match-highlighter.js'
import 'codemirror/addon/search/jump-to-line.js'
import 'codemirror/addon/dialog/dialog.js'
import 'codemirror/addon/dialog/dialog.css'
import 'codemirror/addon/search/searchcursor.js'
import 'codemirror/addon/search/search.js'
In fact, the basic search function of introducing these resources has been realized , Press ctrl+F perhaps command+F The search box appears at the top of the editor .
data:image/s3,"s3://crabby-images/ba40b/ba40b5e6edbcd9f9cb870b37a23953f03983b9b8" alt="image.png"
1.2 Click the button to achieve the search effect
The product takes into account that some people may not know how to use the shortcut key , I designed a button , Click to search , Click the search button , The search box appears at the top of the editor .searchCode It is the corresponding method called when the button is pressed .
methods: {
searchCode (e) {
this.codemirror.execCommand('find') // Trigger
}
}
2. vue-codemirror Folding function
The folding function just started to make this editor and wanted to add , But I tried and I didn't succeed , Because there are many configurations , We also need to introduce resources , So this one is put at the end .
2.1 vue-codemirror Collapse the resources that need to be introduced , There are both style files and js file , These are indispensable
// Fold
import 'codemirror/addon/fold/foldgutter.css'
import 'codemirror/addon/fold/foldcode'
import 'codemirror/addon/fold/foldgutter'
import 'codemirror/addon/fold/brace-fold'
import 'codemirror/addon/fold/comment-fold'
2.2 vue-codemirror The basic configuration required for folding
{
foldGutter: true,
lineWrapping: true,
gutters: ['CodeMirror-linenumbers', 'CodeMirror-foldgutter', 'CodeMirror-lint-markers'],
}
vue-codemirror Folding doesn't need to expand any function , Just introduce the configuration parameters that need resources and configure initialization .
Get editor value and verify function in time
In fact, this function is in vue-codemirror When the code editor value has a syntax error , In time, the button becomes non clickable , When there is nothing wrong with it , The submit button is clickable , No better value to get the editor validation state , Can only think of a small shortcut , Determine if there is an error code , use watch Monitor data , When the data changes , See if there's a mistake . The implementation code is as follows :
watch: {
jsonData (val) {
this.checkValid()
}
},
methods: {
checkValid () {
setTimeout(() => {
this.codemirror.refresh()
const container = this.$refs.codeMirror
const len = container.querySelectorAll('.CodeMirror-lint-marker-error').length
this.isValid = !!len && len > 0
}, 1000)
}
}
The effect is as follows :
data:image/s3,"s3://crabby-images/a55ce/a55ce541c8f44352288539115127849f89dacf6d" alt="image.png"
summary :
Today is mainly followed by 《 Teach you to understand easily vue-codemirror The basic usage of : The main implementation of code editing 、 Verification tips 、 Code formatting 》 The article continues to share vue-codemirror Some uses of , The main implementation of the search 、 Code folding and other functions . It's just my personal opinion , If there is a mistake , Welcome to correct .
Focus on lovepythoncn
**
Reply key :code2, You can get the source code address
版权声明
本文为[Tell me Zhan to hide]所创,转载请带上原文链接,感谢
边栏推荐
- Diamond standard
- Filecoin has completed a major upgrade and achieved four major project progress!
- The difference between gbdt and XGB, and the mathematical derivation of gradient descent method and Newton method
- Use modelarts quickly, zero base white can also play AI!
- Humor: hacker programming is actually similar to machine learning!
- Network security engineer Demo: the original * * is to get your computer administrator rights! [maintain]
- Read the advantages of Wi Fi 6 over Wi Fi 5 in 3 minutes
- Share with Lianyun: is IPFs / filecoin worth investing in?
- Analysis of serilog source code -- how to use it
- 【自学unity2d传奇游戏开发】地图编辑器
猜你喜欢
What knowledge do Python automated testing learn?
意派Epub360丨你想要的H5模板都在这里,电子书、大转盘、红包雨、问卷调查……
事件监听问题
【学习】接口测试用例编写和测试关注点
MongoDB与SQL常用语法对应表
For a while, a dynamic thread pool was created, and the source code was put into GitHub
Using NLP and ml to extract and construct web data
Shh! Is this really good for asynchronous events?
Behind the record breaking Q2 revenue of Alibaba cloud, the cloud opening mode is reshaping
PHP application docking justswap special development kit【 JustSwap.PHP ]
随机推荐
事件监听问题
nacos、ribbon和feign的簡明教程
新建一个空文件占用多少磁盘空间?
CCR coin frying robot: the boss of bitcoin digital currency, what you have to know
How to turn data into assets? Attracting data scientists
What are Devops
华为云微认证考试简介
The dynamic thread pool in Kitty supports Nacos and Apollo multi configuration centers
Live broadcast preview | micro service architecture Learning Series live broadcast phase 3
事务的隔离级别与所带来的问题
GUI engine evaluation index
Markdown tricks
The importance of big data application is reflected in all aspects
StickEngine-架构11-消息队列(MessageQueue)
Installing ns-3 on ubuntu18.04
Filecoin has completed a major upgrade and achieved four major project progress!
Gather in Beijing! The countdown to openi 2020
Cglib 如何实现多重代理?
Shh! Is this really good for asynchronous events?
01. SSH Remote terminal and websocket of go language