목차
주제 1: 사용자 입력 감지: " >주제 1: 사용자 입력 감지:
구현할 기능: " >구현할 기능:
웹 프론트엔드 JS 튜토리얼 [js]: 사용자 입력 감지, 텍스트 상자 기본 스타일 설정, 전체 선택 및 반전 선택 달성을 위한 설계 테이블 스타일

[js]: 사용자 입력 감지, 텍스트 상자 기본 스타일 설정, 전체 선택 및 반전 선택 달성을 위한 설계 테이블 스타일

Aug 07, 2018 am 10:27 AM

주제 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>
로그인 후 복사

주제 2: 텍스트 상자의 기본 스타일 설정:

[js]: 사용자 입력 감지, 텍스트 상자 기본 스타일 설정, 전체 선택 및 반전 선택 달성을 위한 설계 테이블 스타일이 문장은 텍스트 상자;

효과:

<!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>
로그인 후 복사
[js]: 사용자 입력 감지, 텍스트 상자 기본 스타일 설정, 전체 선택 및 반전 선택 달성을 위한 설계 테이블 스타일

주제 3: : 모두 선택 및 반전 기능을 구현하기 위한 테이블 스타일 디자인

구현할 기능:


1 모두 선택 버튼을 클릭할 때 (부모 체크박스), 자식 체크박스의 선택된 상태를 부모 체크박스와 동일하게 만듭니다. 체크박스를 일관되게 유지하세요

2 모든 자식 체크박스에 클릭 이벤트를 등록합니다. 자식 체크박스가 선택되어 있지 않으면 부모의 체크박스를 클릭하세요. 체크박스도 선택되지 않았습니다

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>
로그인 후 복사
웹페이지 예:

[js]: 사용자 입력 감지, 텍스트 상자 기본 스타일 설정, 전체 선택 및 반전 선택 달성을 위한 설계 테이블 스타일

참고: 이 문장이 핵심입니다. 자녀의 체크박스 상태를 다음과 같게 하세요. 상위

sons[i].checked = this.checked;
관련 권장 사항:

js 메소드를 사용하여 모든 확인란을 선택하고 선택 항목을 반전

js 선택한 행의 스타일을 설정하는 구현 코드

위 내용은 [js]: 사용자 입력 감지, 텍스트 상자 기본 스타일 설정, 전체 선택 및 반전 선택 달성을 위한 설계 테이블 스타일의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

내 자신의 JavaScript 라이브러리를 어떻게 작성하고 게시합니까? 내 자신의 JavaScript 라이브러리를 어떻게 작성하고 게시합니까? Mar 18, 2025 pm 03:12 PM

기사는 JavaScript 라이브러리 작성, 게시 및 유지 관리, 계획, 개발, 테스트, 문서 및 홍보 전략에 중점을 둡니다.

브라우저에서 성능을 위해 JavaScript 코드를 최적화하려면 어떻게해야합니까? 브라우저에서 성능을 위해 JavaScript 코드를 최적화하려면 어떻게해야합니까? Mar 18, 2025 pm 03:14 PM

이 기사는 브라우저에서 JavaScript 성능을 최적화하기위한 전략에 대해 설명하고 실행 시간을 줄이고 페이지로드 속도에 미치는 영향을 최소화하는 데 중점을 둡니다.

프론트 엔드 열 용지 영수증에 대한 차량 코드 인쇄를 만나면 어떻게해야합니까? 프론트 엔드 열 용지 영수증에 대한 차량 코드 인쇄를 만나면 어떻게해야합니까? Apr 04, 2025 pm 02:42 PM

프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? 누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? Apr 04, 2025 am 12:09 AM

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

브라우저 개발자 도구를 사용하여 JavaScript 코드를 효과적으로 디버그하려면 어떻게해야합니까? 브라우저 개발자 도구를 사용하여 JavaScript 코드를 효과적으로 디버그하려면 어떻게해야합니까? Mar 18, 2025 pm 03:16 PM

이 기사는 브라우저 개발자 도구를 사용하여 효과적인 JavaScript 디버깅, 중단 점 설정, 콘솔 사용 및 성능 분석에 중점을 둡니다.

JavaScript를 사용하여 동일한 ID와 동일한 ID로 배열 요소를 하나의 객체로 병합하는 방법은 무엇입니까? JavaScript를 사용하여 동일한 ID와 동일한 ID로 배열 요소를 하나의 객체로 병합하는 방법은 무엇입니까? Apr 04, 2025 pm 05:09 PM

동일한 ID로 배열 요소를 JavaScript의 하나의 객체로 병합하는 방법은 무엇입니까? 데이터를 처리 할 때 종종 동일한 ID를 가질 필요가 있습니다 ...

소스 맵을 사용하여 조정 된 JavaScript 코드를 디버그하는 방법은 무엇입니까? 소스 맵을 사용하여 조정 된 JavaScript 코드를 디버그하는 방법은 무엇입니까? Mar 18, 2025 pm 03:17 PM

이 기사는 소스 맵을 사용하여 원래 코드에 다시 매핑하여 미니어링 된 JavaScript를 디버그하는 방법을 설명합니다. 소스 맵 활성화, 브레이크 포인트 설정 및 Chrome Devtools 및 Webpack과 같은 도구 사용에 대해 설명합니다.

Demystifying JavaScript : 그것이하는 일과 중요한 이유 Demystifying JavaScript : 그것이하는 일과 중요한 이유 Apr 09, 2025 am 12:07 AM

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

See all articles