是否可以动态覆盖css?
与CSS一样,我们指定
.mainDiv{
min-height:100px !important
}
是否可以对jquery css执行相同的操作?
我试过
$(".mainDiv").css({"min-height" : ($(window).height() * 0.7) +"px !important"});
但这不起作用。
答案 0 :(得分:2)
最好的方法是使用css覆盖样式,而不是使用jquery。 F.E.你只能添加一个带有jquery的类,并在样式表中定义其余的类。
//script to add a class, this can be anything
$('.mainDiv').click(function(){
$(this).addClass('active');
});
//css to define the different min-heights. (I would not recommend using !important)
.mainDiv {
min-height:100px !important;
}
.mainDiv.active {
min-height:200px !important;
}
答案 1 :(得分:1)
尝试,JQuery不支持important
$(".mainDiv").css({"min-height" : ($(window).height() * 0.7) +"px"});
As这将是内联CSS,因此它将具有首选项
答案 2 :(得分:1)
绝对可以动态覆盖CSS。它是没有被应用的!important属性吗?
确实无法使用.css()方法添加它。但是,您可以使用.attr()方法实现此目的:
$(".mainDiv").attr("style", "min-height: " + ($(window).height() * 0.7) +"px !important");
答案 3 :(得分:0)
答案 4 :(得分:0)
而不是引号(“),而不是使用返回标记,这是jQuery更新css的唯一方法。
$(\`.mainDiv").css({"min-height" : ($(window).height() * 0.7) +"px !important\`});
答案 5 :(得分:0)
尝试不使用{}
$(".mainDiv").css("min-height", ($(window).height() * 0.7) +"px");
您可能还需要单独进行计算,将其保存在变量中,然后使用此变量,例如:
var newHeight = $(window).height() * 0.7;
$(".mainDiv").css("min-height", newHeight +"px");
答案 6 :(得分:0)
试试这个
$(".mainDiv").css({"min-height" : ($(window).height() * 0.7) +"px"});
或只是
$(".mainDiv").attr('style',"min-height:"+($(window).height() * 0.7) +"px !important;");
答案 7 :(得分:0)
检查fiddle。您可以尝试$(".mainDiv").css({"min-height" : ($(window).height() * 0.7) +"px"});
答案 8 :(得分:0)
你可以试试这个
$(document).ready(function() {
$(".mainDiv").attr('style', 'min-height: ' +($(window).height() * 0.7) +"px !important");
});
参考更多Refer Here