Jadual Kandungan
Topic 1 : 检测用户的输入 :" >Topic 1 : 检测用户的输入 :
Topic 2 : 文本框默认样式的设置 :" > Topic 2 : 文本框默认样式的设置 :
Topic 3 :  :设计一个表格的样式实现全选反选的功能" >Topic 3 :  :设计一个表格的样式实现全选反选的功能
Rumah hujung hadapan web tutorial js 【js】:检测用户输入、文本框默认样式设置、设计表格样式实现全选反选

【js】:检测用户输入、文本框默认样式设置、设计表格样式实现全选反选

Aug 07, 2018 am 10:27 AM

Topic 1 : 检测用户的输入 :

题目要求:

编写一个用户注册页面

检测用户名是否是6位以下,密码是否是8位以上,如果不满足要求高亮显示文本框 ;

代码如下 :

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>用户注册页面</title>
	<style>
		.bg {background-color: red; }
	</style>
</head>

<body>
	<!-----id适用于js中的--->
	<input type="text" name="name" id="name" /><br>
	<input type="text" name="pwd" id="pwd" /><br>
	<input type="submit" value="注册" id="submit" />
	
	<script>
//	编写一个用户注册页面
//	检测用户名是否是6位以下,密码是否是8位以上,如果不满足要求高亮显示文本框 ;
		var nameText = document.getElementById(&#39;name&#39;);
		var pwdText = document.getElementById(&#39;pwd&#39;);
		var submit = document.getElementById(&#39;submit&#39;);
		//给submit按钮注册事件
		submit.onclick = function () {
			if(nameText.value.length < 6 && nameText.value.length > 0) {
				nameText.className = &#39;&#39;;
			} else {
				nameText.className = &#39;bg&#39;;
			}
			
			if(pwdText.value.length > 8 && pwdText.value.length < 16) {
				pwdText.className = &#39;&#39;;
			} else {
				pwdText.className = &#39;bg&#39;;
			}
			//取消submit的默认行为的执行   if里面不需要这句了  如果加了肯能会影响后续代码的执行
			return false;
		}
	
	</script>
</body>
</html>
Salin selepas log masuk

Topic 2 : 文本框默认样式的设置 :

1.png

这一句可以设置文本框的默认值;

效果为 :1.png

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>设置文本框中的默认样式</title>
	<style>
		.bg {color: gray; }
		
	</style>
</head>

<body>
	<input type="text" id="textSearch" class="bg" value="请输入关键字" >
	<input type="button" value="搜索">
	
	<script>
		//注册事件
		//如果文本框获得焦点 当内容是请输入关键字 清空内容  文字颜色恢复默认的黑色
		var textSearch = document.getElementById(&#39;textSearch&#39;);
		textSearch.onfocus = function () {
			if(textSearch.value === &#39;请输入关键字&#39;) {
				this.value = &#39;&#39;;
				//把this的属性恢复为默认值   这里作用是把文字颜色变为黑色
				this.className = &#39;&#39;;
			}
		}
		// 当失去焦点的时候onblur。如果文本框中的内容为空  设置文本框中内容为 请输入关键字 设置字体颜色为gray
		textSearch.onblur = function () {
			// if (textSearch.value === &#39;&#39;) {}
			// 这一句不太好的  这个要是用户第一个输入的是空格的话那么就会误判  我们可以用它的长度来判断
			if (textSearch.value.length === 0) {
				this.className = &#39;bg&#39;;
				this.value = &#39;请输入关键字&#39;;
			}
		}

		
	</script>
</body>
</html>
Salin selepas log masuk

Topic 3 : :设计一个表格的样式实现全选反选的功能

要实现的功能:

1 点击全选按钮(父的checkbox)的时候,让子的checkbox的选中状态跟父的checkbox保持一致

2 给所有的子的checkbox注册点击事件,点击子的checkbox 如果有一个子的checkbox没有选中,父的checkbox也不选中

3 反选

代码示例:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>全选反选</title>
    <style>
        * {
            padding: 0;
            margin: 0;
        }

        .wrap {
            width: 300px;
            margin: 100px auto 0;
        }

        table {
            border-collapse: collapse;
            border-spacing: 0;
            border: 1px solid #c0c0c0;
            width: 300px;
        }

        th,
        td {
            border: 1px solid #d0d0d0;
            color: #404060;
            padding: 10px;
        }

        th {
            background-color: #09c;
            font: bold 16px "微软雅黑";
            color: #fff;
        }

        td {
            font: 14px "微软雅黑";
        }

        tbody tr {
            background-color: #f0f0f0;
        }

        tbody tr:hover {
            cursor: pointer;
            background-color: #fafafa;
        }
    </style>
</head>
<body>
  <p class="wrap">
      <table>
          <thead>
            <tr>
                <th>
                    <input type="checkbox" id="father" />
                </th>
                <th>商品</th>
                <th>价钱</th>
            </tr>
          </thead>
          <tbody id="son">
            <tr>
                <td>
                    <input type="checkbox" />
                </td>
                <td>iPhone8</td>
                <td>8000</td>
            </tr>
            <tr>
                <td>
                    <input type="checkbox" />
                </td>
                <td>iPad Pro</td>
                <td>5000</td>
            </tr>
            <tr>
                <td>
                    <input type="checkbox" />
                </td>
                <td>iPad Air</td>
                <td>2000</td>
            </tr>
            <tr>
                <td>
                    <input type="checkbox" />
                </td>
                <td>Apple Watch</td>
                <td>2000</td>
            </tr>

          </tbody>
      </table>
      <input type="button" value="  反 选  " id="btn">
	  <script>
	  	  // 1 点击全选按钮(父的checkbox)的时候,让子的checkbox的选中状态跟父的checkbox保持一致
		  //1.1  给父级的check注册事件
		  //获取父级checkbox 
		  var father = document.getElementById(&#39;father&#39;);
		  //获取所有的子级checkbox
		  //注意这一句用选择器的获得元素的写法
		  var sons = document.querySelectorAll(&#39;#son input[type=checkbox]&#39;);
		  var len = sons.length;
		  father.onclick = function () {
			 //1.2遍历这个容器中的所有元素   让所有的子级checkbox的状态都等于父级的状态
			  for(var i = 0;i < len; i++) {
				  //注意这一句话是核心   让子级的checkbox的状态等于父级
				  sons[i].checked = this.checked;
			  }
		  }
		  
		  
		  
		  // 2 给所有的子的checkbox注册点击事件,点击子的checkbox 如果有一个子的checkbox没有选中,父的checkbox也不选中
		  // 2.1 给所有的子的checkbox注册点击事件
		  // 核心代码封装成方法  便于使用
		  function step2 () {
			  //2.2 只要子级有一个是false那么父级也就是false
			  //2.2 定义一个变量用于父级的状态   这个fatherIsTrue必须在点击事件这里面  father的赋值也是  因为每个点击事件需要判断所有的子级的状态  在外面的话是实现不了的
		 	  var fatherIsTrue = true;
			  for (var j = 0; j < len; j++) {
				  if (!sons[j].checked) {
					  fatherIsTrue = false;
					  break;
					  }
			  }
				  father.checked = fatherIsTrue;
		  }
		  
		  for(var i = 0;i < len; i++) {
			  sons[i].onclick = function () {
				  step2();
			  }
		  }
		  
		  
		  //3 反选
		  // 给反选按钮注册一个事件
		  var btn = document.getElementById(&#39;btn&#39;);
		  btn.onclick = function () {
			  for(var i = 0; i < len; i++) {
				  sons[i].checked = !sons[i].checked;
			  }
			  //写到这里我门会有一个问题就是反选不能控制父级  但是呢我们的第二步已经完成这个问题了  所以我们把第二步
			  //的核心代码分装成一个方法  直接调用即可  直接粘贴复制过来不太好
			  step2();
		  }
	  </script>
  </p>
</body>
</html>
Salin selepas log masuk

网页示例:

1.png

 注意 :这一句话是核心   让子级的checkbox的状态等于父级
 sons[i].checked = this.checked;

相关推荐:

js复选框全选反选的方法

js 设置选中行的样式的实现代码

Atas ialah kandungan terperinci 【js】:检测用户输入、文本框默认样式设置、设计表格样式实现全选反选. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Akan R.E.P.O. Ada Crossplay?
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana saya membuat dan menerbitkan perpustakaan JavaScript saya sendiri? Bagaimana saya membuat dan menerbitkan perpustakaan JavaScript saya sendiri? Mar 18, 2025 pm 03:12 PM

Artikel membincangkan membuat, menerbitkan, dan mengekalkan perpustakaan JavaScript, memberi tumpuan kepada perancangan, pembangunan, ujian, dokumentasi, dan strategi promosi.

Bagaimanakah saya mengoptimumkan kod JavaScript untuk prestasi dalam penyemak imbas? Bagaimanakah saya mengoptimumkan kod JavaScript untuk prestasi dalam penyemak imbas? Mar 18, 2025 pm 03:14 PM

Artikel ini membincangkan strategi untuk mengoptimumkan prestasi JavaScript dalam pelayar, memberi tumpuan kepada mengurangkan masa pelaksanaan dan meminimumkan kesan pada kelajuan beban halaman.

Apa yang perlu saya lakukan jika saya menghadapi percetakan kod yang dihiasi untuk resit kertas terma depan? Apa yang perlu saya lakukan jika saya menghadapi percetakan kod yang dihiasi untuk resit kertas terma depan? Apr 04, 2025 pm 02:42 PM

Soalan dan penyelesaian yang sering ditanya untuk percetakan tiket kertas terma depan dalam pembangunan front-end, percetakan tiket adalah keperluan umum. Walau bagaimanapun, banyak pemaju sedang melaksanakan ...

Siapa yang dibayar lebih banyak Python atau JavaScript? Siapa yang dibayar lebih banyak Python atau JavaScript? Apr 04, 2025 am 12:09 AM

Tidak ada gaji mutlak untuk pemaju Python dan JavaScript, bergantung kepada kemahiran dan keperluan industri. 1. Python boleh dibayar lebih banyak dalam sains data dan pembelajaran mesin. 2. JavaScript mempunyai permintaan yang besar dalam perkembangan depan dan stack penuh, dan gajinya juga cukup besar. 3. Faktor mempengaruhi termasuk pengalaman, lokasi geografi, saiz syarikat dan kemahiran khusus.

Bagaimanakah saya boleh debug kod javascript dengan berkesan menggunakan alat pemaju pelayar? Bagaimanakah saya boleh debug kod javascript dengan berkesan menggunakan alat pemaju pelayar? Mar 18, 2025 pm 03:16 PM

Artikel ini membincangkan debugging JavaScript yang berkesan menggunakan alat pemaju pelayar, memberi tumpuan kepada menetapkan titik putus, menggunakan konsol, dan menganalisis prestasi.

Bagaimana untuk menggabungkan elemen array dengan ID yang sama ke dalam satu objek menggunakan JavaScript? Bagaimana untuk menggabungkan elemen array dengan ID yang sama ke dalam satu objek menggunakan JavaScript? Apr 04, 2025 pm 05:09 PM

Bagaimana cara menggabungkan elemen array dengan ID yang sama ke dalam satu objek dalam JavaScript? Semasa memproses data, kita sering menghadapi keperluan untuk mempunyai id yang sama ...

Bagaimanakah saya menggunakan peta sumber untuk debug kod JavaScript minified? Bagaimanakah saya menggunakan peta sumber untuk debug kod JavaScript minified? Mar 18, 2025 pm 03:17 PM

Artikel ini menerangkan cara menggunakan peta sumber untuk debug JavaScript minifikasi dengan memetakannya kembali ke kod asal. Ia membincangkan membolehkan peta sumber, menetapkan titik putus, dan menggunakan alat seperti Chrome Devtools dan Webpack.

Demystifying JavaScript: Apa yang berlaku dan mengapa penting Demystifying JavaScript: Apa yang berlaku dan mengapa penting Apr 09, 2025 am 12:07 AM

JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.

See all articles