文本编辑器左边显示行数
//調(diào)用方式
?createTextAreaWithLines('codeTextarea');
?
//文本編輯框左側(cè)行數(shù)顯示
function createTextAreaWithLines(id) {
 var el = document.createElement('DIV');
 var ta = document.getElementById(id);
 ta.parentNode.insertBefore(el, ta);
 el.appendChild(ta);
 el.className = 'textAreaWithLines';
 el.style.width = (ta.offsetWidth + 30) + 'px';
 ta.style.position = 'absolute';
 ta.style.left = '30px';
 el.style.height = (ta.offsetHeight + 2) + 'px';
 el.style.overflow = 'hidden';
 el.style.position = 'relative';
 el.style.width = (ta.offsetWidth + 30) + 'px';
 var lineObj = document.createElement('DIV');
 lineObj.style.position = 'absolute';
 lineObj.style.top = lineObjOffsetTop + 'px';
 lineObj.style.left = '0px';
 lineObj.style.width = '27px';
 el.insertBefore(lineObj, ta);
 lineObj.style.textAlign = 'right';
 lineObj.className = 'lineObj';
 var string = '';
 for (var no = 1; no < 5000; no++) {
 if (string.length > 0) string = string + '<br>';
 string = string + no;
 }
 ta.onkeydown = function () { positionLineObj(lineObj, ta); };
 ta.onmousedown = function () { positionLineObj(lineObj, ta); };
 ta.onscroll = function () { positionLineObj(lineObj, ta); };
 ta.onblur = function () { positionLineObj(lineObj, ta); };
 ta.onfocus = function () { positionLineObj(lineObj, ta); };
 ta.onmouseover = function () { positionLineObj(lineObj, ta); };
 lineObj.innerHTML = string;
}
function positionLineObj(obj, ta) {
 obj.style.top = (ta.scrollTop * -1 + lineObjOffsetTop) + 'px';
}
轉(zhuǎn)載于:https://www.cnblogs.com/-netxc/p/4724952.html
總結(jié)
以上是生活随笔為你收集整理的文本编辑器左边显示行数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: ios-晋级之路 CocoaPods引用
- 下一篇: MySQL 5.6 中的 TIMESTA
