gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-01 13:48:15 27 4
gpt4 key购买 nike

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

if (/\S/.test(myString)) {
// string is not empty and not just whitespace
}

所以
<input pattern="\S" required">

if ($('form :invalid'))
console.log('empty');
else
console.log('has non-whitespace char');

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

最佳答案

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

pattern="[\s\S]*\S[\s\S]*"

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

模式属性适用于 <input>仅元素 .

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

$('#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;
}
:valid, .ok {
background:white;
color: green;
}
:invalid, .error {
background:yellow;
color: red;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form method="post">
<textarea name="test" pattern="[\S\s]*\S[\S\s]*" id="test"></textarea>
<input type="submit" />
</form>

关于html - 输入模式,至少 1 个非空白字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34089232/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com