解决方案如何启用/禁用JEditable
感谢Arman的P.概念证明,终于让它与我的网站一起工作。
CODE
//Edit Note
$(function(){
function makeEditable() {
$(".edit").editable('ajax/save.php?editnotetext', {
type : 'mce',
submit : '<button class="save_button">Save</button>',
event: 'dblclick',
indicator : 'Saving...',
tooltip : 'Doubleclick to edit...',
onblur: 'ignore',
width : '700px',
height : '100px',
callback : function(value, settings){
console.log('unlocked');
$.post('ajax/save.php?unlocknotetext', {"id" : $(this).attr('id')});
$(this).effect("highlight", {}, 3000);
$(this).parents('.panel').effect("highlight", {}, 3000);
},
'onreset' : function(){
console.log('unlocked');
$.post('ajax/save.php?unlocknotetext', {"id" : $(this).attr('id')});
}
});
};
makeEditable();
$('.edit').live('click', function() {
console.log('locked');
$.post('ajax/save.php?locknotetext', {"id" : $(this).attr('id')});
});
$(".edit").click(function() {
$.post('ajax/save.php?checklock', {"id" : $(this).attr('id')},
function(data) {
// USE SAME OPTION IN BOTH PLACES
// IF YOU USE 1ST OPTION, YOU CAN TAKE JEDITABLE OUT OF makeEditable() and do everything without that function
if (data[0].is_locked == 1) {
// Option 1
//$(this).editable('disable');
//alert(data[0].username.toUpperCase() + " is editing this note!");
// Option 2
$(".edit").unbind('dblclick');
} else {
// Option 1
//$(this).editable('enable')
// Option 2
makeEditable();
}
},
"json"
);
});
});
UPDATE
所以现在,按照我的想法阿尔曼建议,我做了JEdtiable仅当触发自定义事件工作。只有当我发现没有锁定时,我才会触发事件。但是现在JEditable没有被调用。我试图触发它有什么问题。 [注意JEditable不会被调用,如果,如果我有像<button onclick="$('.edit').trigger('custom_event');">Click to Edit</button>
一个按钮对其进行测试]
CODE
因此,这里是我的新代码
$(function(){
$(".edit").bind("dblclick",function() {
$.ajax({ // first check to see if locked
type: "POST",
url: "ajax/save.php?locknotetext",
data: {"id" : $(this).attr('id')},
dataType: "json",
success: function(data){
if (data[0].is_locked == 1){ // if locked then alert someone is editing ntoe
alert(data[0].username.toUpperCase() + " is editing this note!");
}
else{
$(this).trigger('custom_event');
$(this).unbind('custom_event.editable');
}
}
}); //close $.ajax(
});
});
这里的JEditable件
$(function(){
$(".edit").editable('ajax/save.php?editnotetext', {
type : 'mce',
submit : '<button class="save_button">Save</button>',
event: 'custom_event',
indicator : 'Saving...',
tooltip : 'Doubleclick to edit...',
onblur: 'ignore',
width : '700px',
height : '100px',
callback : function(value, settings){
console.log(this, value, settings);
$(this).effect("highlight", {}, 3000);
$(this).parents('.panel').effect("highlight", {}, 3000);
$.ajax({
type: "POST",
url: "ajax/save.php?unlocknotetext",
data: {"id" : $(this).attr('id')}
}); //close $.ajax(
//$(this).addClass("edit");
}
// },
// function(value, settings) {
// $(this).unbind('settings.event');
});
});
背景
我正在创建一个人们可以共享和编辑笔记的网站。我想要做的是如果有人正在编辑一个笔记,笔记被锁定,以便另一个用户不能编辑笔记。
我正在使用JEditable。用户可以双击以编辑注释。
如果用户双击,我会进行AJAX调用以查看笔记中是否有锁。如果没有,我锁定该笔记,用户可以编辑。如果有锁,我会提醒用户“userX正在编辑注释”。
问题
我的问题是,我只是想打电话JEditable时,有没有锁。否则,我只想提醒用户其他人正在编辑它。我用下面的代码得到的问题是JEditable无论如何都被调用。我也试着使用另一个类名来编辑和添加类,只有在第一个AJAX调用的回调没有锁的时候,但这也不起作用。
任何建议将不胜感激!
我没有使用TinyMCE的与jEditable的状态。我需要知道使用tinyMCE jEditable准确创建了什么来帮助您。如果你能够在线提供你的代码,并给我这个链接,这将对我有很大的帮助。 – 2011-05-10 07:02:38