我正在尝试使用input type=range
更改ace编辑器中某些元素中的文本,但是当我再次尝试编写时,编辑器会在使用javascript修改之前返回上一个值
var editordiv = document.getElementById("editor");
var editor = ace.edit("editor");
editor.getSession().setMode("ace/mode/javascript");
var elem;
editordiv.onmousedown=function(e){
if(e.target.classList.contains("ace_numeric")) elem=e.target;
}
function changeElement(range){
if(elem) elem.textContent=range.value; //not changing correctly editor content
}
#editor{
position:absolute;
width:100%;
height:100%;
}
.ace_constant {
pointer-events:auto !important;
}
#range{
position:absolute;
right:0;
}
<script src="https://cdn.jsdelivr.net/ace/1.2.3/noconflict/ace.js"></script>
<div id="editor">var i=30;
var j=70;</div>
<input type="range" id="range" oninput="changeElement(this)">
如何正确更改数字的值并将历史记录保存在ace编辑器中?
答案 0 :(得分:2)
好的,我找到的解决方案比预期的要复杂一点:
var elem = undefined;
var rn = undefined;
function changeElement(range){
if(rn) editor.session.replace(rn,range.value); //input value into range text
}
editor.on("mousemove",function(e){
if(e.domEvent.target.classList.contains("ace_numeric")){
elem = e.domEvent.target;
var position = e.getDocumentPosition();
var token = editor.session.getTokenAt(position.row, position.column+1);
if(token.value.match(/^[+-]?[.\d]+$/)) //token value is a number
rn = new Range(position.row, token.start, position.row, token.start+elem.textContent.length); //range of text in editor
}
});
不是替换dom元素,而是保存范围位置onmousedown并在输入范围更改时替换文本。
答案 1 :(得分:1)
您需要通过编辑器界面更改编辑器的内容,而不是通过在编辑器中修改dom。一个稍微混乱的方法是使用editor.replace
。您可以根据需要调整正则表达式/参数:
var editordiv = document.getElementById("editor");
var editor = ace.edit("editor");
editor.getSession().setMode("ace/mode/javascript");
function changeElement (range) {
editor.replace('=' + range.value + ';', {needle: /=\d+;/});
}
&#13;
#editor{
position:absolute;
width:100%;
height:100%;
}
.ace_constant {
pointer-events:auto !important;
}
#range{
position:absolute;
right:0;
}
&#13;
<script src="https://cdn.jsdelivr.net/ace/1.2.3/noconflict/ace.js"></script>
<div id="editor">var i=80;</div>
<input type="range" id="range" oninput="changeElement(this)">
&#13;