所以我目前有一个带有两个按钮的jQuery对话框:Save and Close。我使用下面的代码创建对话框:
$dialogDiv.dialog({
autoOpen: false,
modal: true,
width: 600,
resizable: false,
buttons: {
Cancel: function() {
// Cancel code here
},
'Save': function() {
// Save code here
}
},
close: function() {
// Close code here (incidentally, same as Cancel code)
}
});
但是,使用此代码时,两个按钮的颜色相同。我希望我的取消按钮与我的保存颜色不同。有没有办法使用一些内置的jQuery选项来做到这一点?我没有从文档中获得太多帮助。
请注意,我正在创建的“取消”按钮是预定义类型,但“保存”我自己定义。不确定这是否会影响这个问题。
任何帮助将不胜感激。感谢。
更新:达成共识是有两条路可以到达这里:
我使用了第二个选项,并使用了jQuery find()方法,因为我认为这比使用更合适:first或:first-child b / c我想要更改的按钮不一定是第一个标记中列出的按钮。使用find,我只需指定按钮的名称,并以这种方式添加CSS。我最终得到的代码如下:
$dialogDiv.dialog({
autoOpen: false,
modal: true,
width: 600,
resizable: false,
buttons: {
Cancel: function() {
// Cancel code here
},
'Save': function() {
// Save code here
}
},
open: function() {
$('.ui-dialog-buttonpane').find('button:contains("Cancel")').addClass('cancelButtonClass');
}
close: function() {
// Close code here (incidentally, same as Cancel code)
}
});
答案 0 :(得分:121)
我正在将my answer转发给一个类似的问题,因为似乎没有人在这里给它并且它更清洁和更整洁:
使用备用buttons
属性语法:
$dialogDiv.dialog({
autoOpen: false,
modal: true,
width: 600,
resizable: false,
buttons: [
{
text: "Cancel",
"class": 'cancelButtonClass',
click: function() {
// Cancel code here
}
},
{
text: "Save",
"class": 'saveButtonClass',
click: function() {
// Save code here
}
}
],
close: function() {
// Close code here (incidentally, same as Cancel code)
}
});
答案 1 :(得分:13)
您可以使用open事件处理程序来应用其他样式:
open: function(event) {
$('.ui-dialog-buttonpane').find('button:contains("Cancel")').addClass('cancelButton');
}
答案 2 :(得分:6)
我认为有两种方法可以解决这个问题:
当我使用firebug查看我的一个对话框的源代码时,它出现了类似的内容:
<div class="ui-dialog-buttonpane ui-widget-content ui-helper-clearfix">
<button class="ui-state-default ui-corner-all ui-state-focus" type="button">Send</button>
<button class="ui-state-default ui-corner-all" type="button">Cancel</button>
</div>
所以我可以通过向 .ui-state-focus 添加一些样式来解决发送按钮(可能还有一些额外的选择器以确保我覆盖jquery的样式)。
顺便说一句,在这种情况下,我会选择第二个选项,以避免焦点发生变化时出现问题......
答案 3 :(得分:4)
您应该为“class”更改单词“className”
buttons: [
{
text: "Cancel",
class: 'ui-state-default2',
click: function() {
$(this).dialog("close");
}
}
],
答案 4 :(得分:3)
也许是这样的?
$('.ui-state-default:first').addClass('classForCancelButton');
答案 5 :(得分:3)
选择具有角色对话框的div,然后在其中获取相应的按钮并设置CSS。
$("div[role=dialog] button:contains('Save')").css("color", "green");
$("div[role=dialog] button:contains('Cancel')").css("color", "red");
答案 6 :(得分:2)
还有一个简单的答案,用于定义仅应用于该特定按钮的特定样式,并且在声明对话框时可以让Jquery声明元素样式:
id: "button-delete",
text: "Delete",
style: "display: none;",
click: function () {}
执行此操作允许您进行设置,但稍后使用jquery进行更改并不一定容易。
答案 7 :(得分:1)
为什么不检查生成的标记,注意选择按钮上的类并自行设置样式?
答案 8 :(得分:0)
我建议你看看代码吐出的HTML,看看是否有一种方法可以唯一地标识一个(或两个)按钮(可能是id或name属性),然后使用jQuery来选择该项并将css类应用于它。
答案 9 :(得分:0)
如果仍然需要注意,请在页面样式表中添加以下样式
.ui-widget-content .ui-state-default {
border: 0px solid #d3d3d3;
background: #00ACD6 50% 50% repeat-x;
font-weight: normal;
color: #fff;
}
它将改变对话框按钮的背景颜色。