我希望用户能够确认他们在选择控件中所做的选择,或者如果他们取消则回滚到以前的值。以下在 Chrome/Safari 中运行良好,但无论我尝试什么,我都无法让它在 Firefox(在 Mac 上)中运行。
HTML:
<select id='my-select'>
<option value="client">Client</option>
<option selected="selected" value="assistant">Assistant</option>
<option value="manager">Manager</option>
</select>
JS:
$('#my-select').focus(function() {
//Store old value
$(this).data('lastValue',$(this).val());
});
$('#my-select').change(function(e) {
var lastRole = $(this).data('lastValue');
var newRole = $(this).val();
if(confirm("Change user's role from "+lastRole+" to "+newRole+"?"))
{
// The control may remain in focus, so we update lastValue here:
$(this).data('lastValue',newRole);
// Do stuff
}
else {
$(this).val(lastRole);
}
});
小提琴:http: //jsfiddle.net/yxzqY/13/
该问题可以证明如下:
- 选择“经理”
- 单击“取消”(所选值 =“助手”)
- 再次选择“经理”
- 单击“取消”(选定值 = Chrome中的“助手”,选定值 = FireFox 中的“经理” )
我只是被难住了——不知道如何在 Firefox 中使用它,或者如何解决跨浏览器的差异行为。