如何从 Wicket 组件中删除 CSS 类?

2022-09-03 13:55:48

使用 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(但也可以随意发布针对更高版本的建议)。


答案 1

这是我想到的一种方法:

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 子类,但是将逻辑放在单独的实用程序类或方法中会清理很多。

编辑:改进的版本,可以更好地处理角落情况(请参阅biziclop的评论)。注意:使用番石榴。(欢迎您发布更简单(正则表达式?)版本。newValue()

@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); 
}

答案 2

基于Jonik的答案,以下内容添加了负面的展望,以忽略不同样式类中间的发生(并且不区分大小写)。

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


推荐