输入模式,至少 1 个非空白字符

dit*_*tto 4 html regex

我想将以下内容重写为 HTML 模式:

if (/\S/.test(myString)) {
    // string is not empty and not just whitespace
}
Run Code Online (Sandbox Code Playgroud)

所以

<input pattern="\S" required">

if ($('form :invalid'))
    console.log('empty');
else
    console.log('has non-whitespace char');
Run Code Online (Sandbox Code Playgroud)

问题是我的模式与测试字符串的工作方式不同。我想检查是否至少有 1 个非空白字符。

Wik*_*żew 6

pattern属性需要完整的字符串匹配,并且模式会自动锚定(无需使用^and $)。因此,要至少需要 1 个非空格,请使用

pattern="[\s\S]*\S[\s\S]*"
Run Code Online (Sandbox Code Playgroud)

由于您正在验证多行文本(即包含换行符的文本),您需要将它们与[\s\S]或与[^]结构。

模式属性会与<input>元素只

要验证textarea字段,您可以创建自定义pattern属性验证:

pattern="[\s\S]*\S[\s\S]*"
Run Code Online (Sandbox Code Playgroud)
$('#test').keyup(validateTextarea);

function validateTextarea() {
        var errorMsg = "Please match the format requested.";
        var textarea = this;
        var pattern = new RegExp('^' + $(textarea).attr('pattern') + '$');
        var hasError = !$(this).val().match(pattern); // check if the line matches the pattern
         if (typeof textarea.setCustomValidity === 'function') {
            textarea.setCustomValidity(hasError ? errorMsg : '');
         } else { // Not supported by the browser, fallback to manual error display
            $(textarea).toggleClass('error', !!hasError);
            $(textarea).toggleClass('ok', !hasError);
            if (hasError) {
                $(textarea).attr('title', errorMsg);
             } else {
                $(textarea).removeAttr('title');
             }
         }
         return !hasError;
    }
Run Code Online (Sandbox Code Playgroud)
:valid, .ok {
    background:white;
    color: green;
}
:invalid, .error {
    background:yellow;
    color: red;
}
Run Code Online (Sandbox Code Playgroud)