使用AttributeAppender动态将CSS类添加到Java代码中的组件非常简单:
component.add(new AttributeAppender("class", true, new Model<String>("foo"), " "));
或者,如果您已将上述内容提取到适当的实用方法或类中,则只需:
component.add(WicketUtils.cssClassAppender("foo"));
但是如何删除CSS类?
您可以通过完全清除class属性轻松删除所有 CSS类:
component.add(new SimpleAttributeModifier("class", ""));
...但如果组件有不希望删除的其他CSS类,那么这是不可接受的。
Wicket 1.4(但也可以随意发布针对更高版本的建议)。
答案 0 :(得分:17)
这是我提出的一种方式:
public class CssClassRemover extends AttributeModifier {
public CssClassRemover(String cssClass) {
super("class", false, new Model<String>(cssClass));
}
@Override
protected String newValue(String currentValue, String valueToRemove) {
// NB: naive approach; breaks with e.g. "foo foo-bar" & "foo"
return currentValue.replaceAll(valueToRemove, "");
}
}
使用上述帮助程序的代码将是:
component.add(new CssClassRemover("foo"))
(当然你也可以根据需要创建匿名的AttributeModifier子类,但是将逻辑放在一个单独的实用程序类或方法中可以清理它。)
修改:newValue()
的改进版本,可以更好地处理边角情况(请参阅biziclop的评论)。注意:使用Guava。 (欢迎发布更简单(正则表达式)版本。)
@Override
protected String newValue(String currentValue, String valueToRemove) {
if (currentValue == null) return "";
Set<String> classes = Sets.newHashSet(Splitter.on(" ").split(currentValue));
classes.remove(valueToRemove);
return Joiner.on(" ").join(classes);
}
答案 1 :(得分:3)
在Jonik's answer上构建,以下内容添加了否定前瞻,以忽略不同样式类中间的出现(并且不区分大小写)。
public class StyleClassRemover extends AttributeModifier {
public StyleClassRemover(final String cssClass) {
super("class", false, Model.of(cssClass));
}
@Override
protected String newValue(final String currentValue, final String valueToRemove) {
if (currentValue == null) {
return "";
}
final String patternString = "(^|\\s+)" + Pattern.quote(valueToRemove) + "(?!\\S)";
return Pattern.compile(patternString, Pattern.CASE_INSENSITIVE).matcher(currentValue).replaceAll("");
}
}
测试输入: http://fiddle.re/ah0ca6
答案 2 :(得分:0)
Wicket 1.5+有org.apache.wicket.AttributeModifier #remove()