はじめに
メモ用に、MovableType.net フォームのバリデーションをコピペでつかえるように・・
2-3個チェックしたけど、設置後は自分でチェックしてね・・おいらも含めて。w
設置例
コピペエリア
1行テキストの部分を自分の定義した名前に置き換えてね
下記の2行は、1つで・・・
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
カタカナ
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^[\u30A0-\u30FF|\s]+$/.test(value)) {
return "このフィールドはカタカナで入力してください。";
}
}
}
]);
ひらがな
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^[\u3040-\u309F|\s]+$/.test(value)) {
return "このフィールドはひらがなで入力してください。";
}
}
}
]);
携帯番号
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^\d{3}-\d{4}-\d{4}$|^\d{11}$/.test(value)) {
return "このフィールドは携帯番号形式で入力してください。";
}
}
}
]);
電話番号&携帯番号
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^([\+][0-9]{1,3}([ \.\-])?)?([\(][0-9]{1,6}[\)])?([0-9 \.\-]{1,32})(([A-Za-z \:]{1,11})?[0-9]{1,4}?)$/.test(value)) {
return "このフィールドは電話番号形式で入力してください。";
}
}
}
]);
郵便番号
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^\d{3}-\d{4}$/.test(value)) {
return "このフィールドは電話番号形式で入力してください。";
}
}
}
]);
メールアドレス
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i.test(value)) {
return "このフィールドはメールアドレス形式で入力してください。";
}
}
}
]);
整数
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^[\-\+]?\d+$/.test(value)) {
return "このフィールドは整数で入力してください。";
}
}
}
]);
数値+-カンマあり
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^[\-\+]?((([0-9]{1,3})([,][0-9]{3})*)|([0-9]+))?([\.]([0-9]+))?$/.test(value)) {
return "このフィールドは数値で入力してください。";
}
}
}
]);
日付
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^\d{4}\/\d{1,2}\/\d{1,2}$/.test(value)) {
return "このフィールドは半角で YYYY/MM/DDで入力してください。";
}
}
}
]);
時間
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^([01]?[0-9]|2[0-3]):([0-5][0-9])$/.test(value)) {
return "このフィールドは半角で HH:MMで入力してください。";
}
}
}
]);
IPアドレスv4
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^((([01]?[0-9]{1,2})|(2[0-4][0-9])|(25[0-5]))[.]){3}(([0-1]?[0-9]{1,2})|(2[0-4][0-9])|(25[0-5]))$/.test(value)) {
return "このフィールドはIPアドレス形式で入力してください。";
}
}
}
]);
URL
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^(https?|ftp):\/\/(((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/i.test(value)) {
return "このフィールドはURL形式で入力してください。";
}
}
}
]);
半角英数字 -_含む
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^[a-zA-Z0-9\-_]+$/.test(value)) {
return "このフィールドは半角英数字で入力してください。";
}
}
}
]);
数値 0か数値
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^(0|[1-9]\d*)$/.test(value)) {
return "このフィールドは数値で入力してください。";
}
}
}
]);
数値
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^([0-9]\d*)$/.test(value)) {
return "このフィールドは数値で入力してください。";
}
}
}
]);
小数点形式
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^(0|-?[1-9]\d*|-?(0|[1-9]\d*)\.\d+)$/.test(value)) {
return "このフィールドは小数点形式で入力してください。";
}
}
}
]);
カンマ形式
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^(0|[1-9]\d{0,2}(,\d{3})*)$/.test(value)) {
return "このフィールドはカンマ形式で入力してください。";
}
}
}
]);
半角英数字
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^[\s0-9A-Za-z]+$/.test(value)) {
return "このフィールドは半角英数字で入力してください。";
}
}
}
]);
半角英数字空白を含む
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^[\s0-9A-Za-z]+$/.test(value)) {
return "このフィールドは半角英数字で入力してください。";
}
}
}
]);
半角英数字
window.MTNetFormDataLayer = window.MTNetFormDataLayer || [];
function MTNetForm() { MTNetFormDataLayer.push(arguments); }
MTNetForm("validator", [
{
id: "1行テキスト",
validator: function(value) {
if(!/^[0-9a-zA-Z]+$/.test(value)) {
return "このフィールドは半角英数字で入力してください。";
}
}
}
]);
さいごに
未来のおいら。コピペ後は、チェックしろよ・・・
関連記事
MovableType.net フォームつかってみた。
https://www.omakase.net/blog/2022/11/movabletypenet-1.html