Maison >interface Web >js tutoriel >Choses à noter lors de l'écriture d'une zone de texte JavaScript scripts_javascript tips

Choses à noter lors de l'écriture d'une zone de texte JavaScript scripts_javascript tips

WBOY
WBOYoriginal
2016-05-16 15:18:321396parcourir

En HTML, il existe deux manières de représenter les zones de texte :

L'un est une seule ligne de texte utilisant des éléments de saisie, et l'autre est une zone de texte multiligne utilisant une zone de texte.

Pour utiliser la méthode de saisie, le type doit être ajouté et défini sur "texte".

    La propriété
  • size permet de préciser le nombre de caractères pouvant être affichés dans la zone de texte.
  • L'attribut
  • value peut définir la valeur initiale de la zone de texte.
  • L'attribut
  • maxlength est utilisé pour spécifier le nombre maximum de caractères pouvant être acceptés dans la zone de texte.

La valeur initiale de textarea doit être placée entre les balises de début et de fin.

  • cols est le nombre de lignes de caractères de la zone de texte
  • lignes est le nombre de colonnes de caractères de la zone de texte

De plus, vous ne pouvez pas spécifier le nombre maximum de caractères pour la zone de texte en HTML

;

1. Sélectionnez le texte

Les deux zones de texte ci-dessus sont prises en charge

  • Méthode select(), cette méthode est principalement utilisée pour sélectionner tout le texte dans la zone de texte. N'accepte aucun paramètre.
  • L'événement select correspondant à cette méthode est déclenché lorsque le texte dans la zone de texte est sélectionné.

1. Méthode select()

Le code suivant sélectionnera tout le texte tant que la zone de texte obtient le focus :

var textBox = document.getElementById("myForm").elements["firstName"];
//设置默认值
textBox.value = "input your firstName";
//设置事件
textBox.addEventListener("focus", function () {
  event.target.select();
});

2. sélectionnez l'événement

Quand cet événement est déclenché :

  • Généralement, l'événement select sera déclenché uniquement lorsque l'utilisateur sélectionne du texte (et relâche la souris)
  •  ;
  • Dans IE8 et les versions antérieures, tant que l'utilisateur sélectionne une lettre (sans relâcher la souris), l'événement select sera déclenché
  • sera également déclenché lorsque la méthode select() est appelée
  •  ;

Par exemple :

var textBox = document.getElementById("myForm").elements["firstName"];
//设置默认值
textBox.value = "input your firstName";
//设置事件
textBox.addEventListener("select", function () {
  console.log("selected");
});

3. Récupérez le texte sélectionné

Utilisation de deux attributs :

  • sélectionDébut
  • sélectionFin

Ces deux attributs stockent des valeurs basées sur 0, indiquant la plage (décalage) du texte sélectionné. Par conséquent, pour obtenir le texte dans la zone de texte sélectionnée par l'utilisateur, vous pouvez utiliser le code suivant :

var textBox = document.getElementById("myForm").elements["firstName"];
//设置默认值
textBox.value = "input your firstName";
//设置事件
textBox.addEventListener("select", function () {
  var selected = textBox.value.substring(textBox.selectionStart,textBox.selectionEnd);
  console.log(selected); 
});

De plus, vous pouvez également utiliser cet attribut pour définir l'état par défaut de sélection complète lorsque le focus est obtenu :

textBox.addEventListener("focus", function () {
  textBox.selectionStart = "0";
  textBox.selectionEnd = textBox.value.length;
});

ou :

textBox.addEventListener("focus", function () {
  textBox.blur();
});

Cependant, lors de l'utilisation des attributs selectionStart/End, IE8 ne le prend pas en charge, mais en prend en charge un autre nommé

  • Objet document.selection, qui stocke les informations textuelles sélectionnées par l'utilisateur dans l'ensemble du document

Obtenir la version compatible du texte sélectionné :

function getSelectedText (textbox) {
  if (typeof textbox.selectionStart == "number") {
    return textbox.value.substring(textbox.selectionStart,textbox.selectionEnd);
  }else if (document.selection) {
    return document.selection.createRange().text;
  }
}

2. Sélectionnez une partie du texte

La méthode pour sélectionner une partie du texte est :

Méthode setSelectionRange() . Reçoit deux paramètres : l'index du premier caractère à sélectionner et l'index du dernier caractère.
Pour bloquer la sélection d'un utilisateur :

textBox.addEventListener("focus", function () {
  textBox.setSelectionRange(0,0);
});
textBox.addEventListener("select", function () {
  textBox.setSelectionRange(0,0);
});

Pour définir le focus sur la zone de texte immédiatement avant ou après l'appel de setSelectionRange(). La méthode utilisée dans IE est le champ d'application pour résoudre les problèmes de texte :

var range = textBox.createTextRange();
range.collapse(true); //范围折叠到开头
range.moveStart("Character",0);
range.moveEnd("Character",textBox.value.length);
range.select();

Version compatible : plus couramment utilisée

function selectText(textbox, startIndex, stopIndex) {
  if (textbox.setSelectionRange) {
    textbox.setSelectionRange(startIndex, stopIndex);
  } else if (textbox.createTextRange()) {
    var range = textbox.createTextRange();
    range.collapse(true); //范围折叠到开头
    range.moveStart("Character", startIndex);
    range.moveEnd("Character", stopIndex);
    range.select();
  };
}

3. Entrée du filtre

1. Bloquer des personnages

Le code suivant permet uniquement de saisir des chiffres :

var textBox = document.getElementById("myForm").elements["firstName"];
textBox.autofocus = true;
textBox.addEventListener("keypress", function () {
  if (!/\d/.test(String.fromCharCode(event.charCode))) { //仅输入数字
    event.preventDefault();
  };
});

Cependant, certains navigateurs déclencheront des événements de pression sur les touches haut, bas et retour arrière, vous devez donc débloquer ces touches d'opération couramment utilisées, tant que vous ne bloquez pas les touches dont l'encodage des caractères est inférieur à 10 :

textBox.addEventListener("keypress", function () {
  if (!/\d/.test(String.fromCharCode(event.charCode)) && event.charCode > 9 && !event.ctrlKey) { //仅输入数字
    event.preventDefault();
  };
});

四、操作剪贴板

以下是6个剪贴板事件

  • beforecopy:在发生复制操作前触发
  • copy:在发生复制时触发
  • beforecut:在发生剪贴前操作
  • cut:在发生加贴时操作
  • beforepaste:在发生黏贴操作前触发
  • paste:在发生黏贴操作时触发

如设置禁止拷贝:

//拷贝之前提示禁止拷贝
textBox.addEventListener("beforecopy", function() {
  textBox.value = "do not copy";
});
//拷贝时禁止拷贝
textBox.addEventListener("copy", function() {
  event.preventDefault();
});

要访问剪贴板中的数据,可以使用clipboardData对象,在IE中,这个对象是window对象的属性,在friefox,safari和chrome,这个对象是相应event对象的属性;在IE中可以随时访问该对象;但在其他浏览器中只有在处理剪贴板事件期间才有效。

这个clipboardData对象有三个方法:

  • getData()
  • setData()
  • clearData()

getData()接收一个参数,即要取得数据的格式(IE中有两种数据格式:text和URL;在其他浏览器中这个参数是一种MIME类型;不过可以用text代替text/plain)。

setData()接收两个参数,即数据类型和要放在剪贴板中的文本。(第一个参数中,IE支持text和URL;第二个参数中chrome和safari不支持text类型);这两个浏览器在成功将文本放到剪贴板中后,都会返回true;否则,返回false:

function getClipboardText(event) {
  var clipboardData = (event.clipboardData || window.clipboardData);
  return clipboardData.getData("text");
}

function setClipboardText(event, value) {
  if (event.clipboardData) {
    return event.clipboardData.setData("text/plain", value);
  } else if (window.clipboardData) {
    return window.clipboardData.setData("text", value);
  }
}

目前浏览器逐渐收紧对访问剪贴板的操作。

五、自动切换焦点

理论上就是在前一个文本框中的字符打到最大数量后,自动将焦点切换到下一个文本框:

DOM:

<form action="">
  <input type="text" name="tel11" id="txtTel1" maxLength="3">
  <input type="text" name="tel12" id="txtTel2" maxLength="3">
  <input type="text" name="tel13" id="txtTel3" maxLength="4">
  <input type="submit" name="btn" id="btn" value="submit">
</form>

js:

var textbox1 = document.getElementById("txtTel1");
var textbox2 = document.getElementById("txtTel2");
var textbox3 = document.getElementById("txtTel3");

textbox1.addEventListener("keyup", tabForward);
textbox2.addEventListener("keyup", tabForward);
textbox3.addEventListener("keyup", tabForward);

function tabForward() {
  var target = event.target;
  //当value长度等于最大值的时候
  if (target.value.length == target.maxLength) {
    var form = target.form;
    //遍历所在的form表单中的元素
    for (var i = 0, len = form.elements.length; i < len; i++) {
      //如果该元素是目标元素
      if (form.elements[i] == target) {
        //并且该元素的下一个元素为true 其他条件
        if ((form.elements[i + 1]) && (form.elements[i + 1].nodeType == 1) && (form.elements[i + 1].tagName.toLowerCase() == "input") && (form.elements[i + 1].type == "text")) {
          //则下个元素获得焦点
          form.elements[i + 1].focus();
        }
      }
    };
  }
}

六、HTML5约束验证API

1、必填字段required属性

在必填字段中添加属性required。它适用于input,textarea,select字段。使用下面的代码可以检测浏览器是否支持required属性:

var isRequiredSupported="required" in document.createElement("input");

2、其他输入类型

input的type属性增加了“email”和“url”;各浏览器也都为它们增加了定制的验证机制:

var input = document.createElement("input");
input.type = "email";
var isEmailSupported = (input.type == "email");

3、数值范围

除了“email”和“URL”,HTML5还定义了另外几个输入元素。这几个元素都要求填写基于数字的值:“number”,“range”,“datetime”,“datetime-local”,“date”,“mouth”,“week”,“time”。目前浏览器对这些类型支持并不好,如果真想使用的话要小心。

对这事数值类型的输入元素可以指定min属性,max属性,step属性。同时这些数值类型元素还有两个方法:stepUp(),stepDown()。都接受一个参数,要在当前基础上加上或减去的数值。

DOM:

<form action="">
  <input type="range" name="tel14" id="txtTel4" required min="10" max="20" step="1">
  <input type="button" value="up" id="up">
  <input type="text" id="output">
  <input type="submit" name="btn" id="btn" value="submit">
</form>

js:

var input = document.getElementById("txtTel4");
var up = document.getElementById("up");

input.addEventListener("mousemove", function () {
  var output = document.getElementById("output");
  output.value = input.value;
});
up.addEventListener("click", function () {
  //点击value值以2为单位增加
  input.stepUp(2);
  var output = document.getElementById("output");
  output.value = input.value;
});

3、输入模式

HTML5新增了pattern属性,这个属性的值是一个正则表达式,用于匹配文本框中的值。

<input type="text" id="number" pattern="\d{3}">

var num = document.getElementById("number");
console.log(num.pattern); //\d{3}

可以使用以下代码来检测浏览器是否支持pattern属性:

var isPatternSupported="pattern" in document.createElement("input");

4、检测有效性

使用checkValidity()方法可以检测表单中的字段是否有效。所有表单的字段都有这个方法,如果检查有效返回true。

<form action="">
  <input type="text" pattern="w" id="name" required>
  <input type="number" max="10" id="num" required>
  <input type="button" id="check" value="check">
  <input type="submit" id="submit" value="submit" disabled>
</form>

var form = document.forms[0];
var name = document.getElementById("name");
var number = document.getElementById("num");
var check = document.getElementById("check");
var submit = document.getElementById("submit");

check.addEventListener("click", function () {
  console.log(form.checkValidity()); //检测整个表单是否正确
  if (form.checkValidity()) {
    submit.removeAttribute("disabled");
    check.disabled = true;
  }else{
    alert("请检查表单");
  }
});

input的validity属性会给出什么字段有效和无效的具体信息。

var inputName = document.getElementById("inputName");
inputName.onblur = function() {
  if (inputName.checkValidity()) {
    inputName.style.color = "white";
    inputName.style.backgroundColor = "green";

  } else {
    inputName.style.color = "white";
    inputName.style.backgroundColor = "red";
    if (inputName.validity.patternMismatch) {
      inputName.value = "请填写正确的格式";
    }
  }
};
inputName.addEventListener("mouseenter", function () {
  inputName.focus();
  inputName.select();
});

La validité comprend principalement les attributs suivants :

  • customError : si setCustomValidity() est défini ;
  • patternMismatch : s'il correspond à l'attribut de motif
  • rangeOverflow : s'il est supérieur à la valeur maximale
  • rangeUnderflow : s'il est inférieur à la valeur minimale
  • stepMisMatch : si la taille du pas est raisonnable ;
  • tooLong : si la longueur maximale est dépassée
  • typeMismatch : s'il ne s'agit pas du type de courrier et du type d'url ;
  • valide : si les autres attributs ici sont faux, retournez vrai
  • valueMissing : S'il n'y a aucune valeur requise, renvoie true.

5. Désactiver la vérification

En définissant l'attribut novalidate du formulaire, le formulaire ne peut pas être vérifié. Après avoir obtenu le formulaire à l'aide de js, définir son attribut novalidate sur true désactivera la validation du formulaire.

L'ajout de l'attribut formnovalidate au bouton de soumission ne validera pas le formulaire soumis. Après avoir utilisé js pour obtenir le bouton de soumission, définissez son attribut formnovalidata sur true, ce qui désactivera la validation du formulaire et le soumettra.
Ce qui précède représente l'intégralité du contenu de cet article, j'espère qu'il sera utile à l'étude de chacun.

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn