[英]set created input text selected using jquery
我有以下标签:
<div id="email">
<label>
myemail@gmail.com
</label>
<i class="fa fa-edit"></i>
</div>
<div id="phone">
<label>
1234567890
</label>
<i class="fa fa-edit"></i>
</div>
当我单击编辑按钮时,我想用输入替换标签,并将标签值设置为选中状态。 以下是我到目前为止尝试过的方法:
$('.fa-edit').click(function(){
var info = $(this).closest('div');
var label = info.find('label');
var curr_value = label.text();
label.replaceWith('<input class="edit_input" type="text" value="'+curr_value+'" />')
.focus(function(){
//alert(this);
this.select();
});
// some code ..
问题是我无法将输入文本设置为选中状态(准备替换)。 我该怎么办?
创建输入元素并设置焦点并在替换标签后对其进行选择。
请检查以下代码:
$("#editBtn").click(function(){ var label = $(this).parent().find('label'); var curr_value = label.text().trim(); var newInput = $('<input class="edit_input" type="text" value="'+curr_value+'" />') label.replaceWith(newInput) newInput.focus().select() })
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <div id="email"> <label> myemail@gmail.com </label> <button id="editBtn">EDIT</button> </div>
从.replaceWith返回的值仍然是旧的<label />
引用,您需要重新选择输入,以便可以将其聚焦。
label.replaceWith('<input class="edit_input" type="text" value="'+curr_value+'" />')
$('.edit_input').off('focus').on('focus',function() {
this.select()
}).trigger('focus')
每次用户再次单击编辑按钮时,请使用off()删除以前的事件侦听器。
希望对您有所帮助。
var label = $('label');
var curr_value = label.text();
label.replaceWith('<input class="edit_input" type="text" value="'+curr_value+'" />').focus(function(){
$(this).select(); });
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.