我有一个文本输入

<input type="text" value="3" class="field left">

这是我的CSS

background:url("images/number-bg.png") no-repeat scroll 0 0 transparent;
border:0 none;
color:#FFFFFF;
height:17px;
margin:0 13px 0 0;
text-align:center;
width:17px; 

有什么设定或技巧吗,我想做一个标签,但是样式如何。我如何转换它们,有没有更好的方法或者这是唯一的方法?


当前回答

如果你真的想使用CSS,使用下面的属性将使字段不可编辑。

pointer-events: none;

其他回答

你只需要在最后添加disabled

<input type="text" value="3" class="field left" disabled>

你可以在输入中添加属性readonly:

<input type="text" value="3"
       class="field left" readonly="readonly">

更多信息: http://www.w3schools.com/tags/att_input_readonly.asp

只读和禁用将工作。但如果你想发送输入值,只需使用readonly并编辑css .field left:focus{outline: none}

<input type="text" value="3" class="field left" readonly>

不需要造型。

参见MDN上<input> https://developer.mozilla.org/en/docs/Web/HTML/Element/input#Attributes

在某些情况下,您只是想使输入元素不可编辑或不可更改,这意味着文本游标仍然可以放在那里,游标可以四处移动,但只有文本保持不变。它不同于readOnly或disabled。

主持人(jsfiddle)

document.getElementById('input') .addEventListener('keydown', (e) => { var 字段 = e.target; var oldValue = field.value; setTimeout(function() { if(field.value !== oldValue) { 字段值 = 旧值; } }, 1); }) <输入 id=“input”, type=“text” 值=“default” class=“field left”>

使用JQuery (jsfiddle)

$("input").keydown(function(e) {
var oldValue=$(this).val();
var field=this;
setTimeout(function () {
    if(field.value !== oldValue) {
        $(field).val(oldValue);
    } 
}, 1);
});
<input id="input", type="text" value="default" class="field left">