上一次内容进行复习:javascript
CSS: 层叠样式表css
主要做用: 美化页面, 将美化和HTML进行分离,提升代码复用性html
选择器:java
元素选择器: 元素的名称{}node
类选择器: . 开头数组
ID选择器: #ID选择器浏览器
后代选择器: 选择器1 选择器2app
子元素选择器: 选择器1 > 选择器2 ide
选择器分组: 选择器1,选择器2,选择器3{}函数
属性选择器: 选择器[属性的名称='属性的值']
伪类选择器:
浮动:
float 属性: left right
清除浮动:
clear 属性: both left right
盒子模型: 上右下左 padding 10px 20px 30px 40px 顺时针的方向
内边距: 控制的盒子内距离
边框: 盒子的边框
外边距: 控制盒子与盒子之间的距离
绝对定位: position : absolute; top: left
JS开发: 是一门脚本语言,由浏览器来解释执行,不须要通过编译
JS声明变量: var 变量的名字;
JS声明函数: function 函数的名称(参数的名字){}
JS开发的步骤:
1. 肯定事件 2. 事件要触发函数,因此咱们是要声明函数 3. 函数里面一般是去作一些交互才操做, 弹框, 修改页面内容,动态去添加一些东西
有一组图片, 每隔3秒钟,就去切换一张,最终是一直在不停切换
切换图片:
每一个三秒钟作一件事:
1. 肯定事件: 文档加载完成的事件 onload 2. 事件要触发 : init() 3. 函数里面要作一些事情:(一般会去操做元素,提供交互) 1. 开启定时器: 执行切换图片的函数 changeImg() 4. changeImg() 1. 得到要切换图片的那个元素
通常网页,当咱们刚打开的时候,它会5秒以后,显示一个广告,让咱们看5秒钟,而后他的广告就自动消失了!
定时器
init函数里面作一件事:
显示一个广告
<script> function init(){ setTimeout("showAD()",3000); } function showAD(){ //首先要获取要操做的img var img = document.getElementById("img1"); //显示广告 img.style.display = "block"; //再开启定时器,关闭广告 setTimeout("hideAD()",3000); } function hideAD(){ //首先要获取要操做的img var img = document.getElementById("img1"); //隐藏广告 img.style.display = "none"; } </script>
昨天咱们作了一个简单的表单校验,每当用户输入出错的时候,咱们是弹出了一个对话框,提示用户去修改。这样的用户体验效果很是很差好。咱们今天就是须要来对他进行一个修改,当用户输入信息有问题的时候,咱们就再输入框的后面给他一个友好提示。
【HTML中innerHTML属性】
【JS中的经常使用事件】
onfocus 事件: 得到焦点事件
onblur : 失去焦点
onkeyup : 按键抬起事件
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <!-- 引入外部的js文件 --> <script type="text/javascript" src="../js/regutils.js" ></script> <script> /* 1. 肯定事件 : onfocus 2. 事件要驱动函数 3. 函数要干一些事情: 修改span的内容 */ function showTips(spanID,msg){ //首先要得到要操做元素 span var span = document.getElementById(spanID); span.innerHTML = msg; } /* 校验用户名: 1.事件: onblur 失去焦点 2.函数: checkUsername() 3.函数去显示校验结果 */ function checkUsername(){ //获取用户输入的内容 var uValue = document.getElementById("username").value; //对输入的内容进行校验 //得到要显示结果的span var span = document.getElementById("span_username"); if(uValue.length < 6){ //显示校验结果 span.innerHTML = "<font color='red' size='2'>对不起,过短</font>"; return false; }else{ span.innerHTML = "<font color='red' size='2'>恭喜您,可用</font>"; return true; } } /* 密码校验 */ function checkPassword(){ //获取密码输入 var uPass = document.getElementById("password").value; var span = document.getElementById("span_password"); //对密码输入进行校验 if(uPass.length < 6){ span.innerHTML = "<font color='red' size='2'>对不起,过短</font>"; return false; }else{ span.innerHTML = "<font color='red' size='2'>恭喜您,够用</font>"; return true; } } /* 确认密码校验 * */ function checkRePassword(){ //获取密码输入 var uPass = document.getElementById("password").value; //获取确认密码输入 var uRePass = document.getElementById("repassword").value; var span = document.getElementById("span_repassword"); //对密码输入进行校验 if(uPass != uRePass){ span.innerHTML = "<font color='red' size='2'>对不起,两次密码不一致</font>"; return false; }else{ span.innerHTML = ""; return true; } } /* 校验邮箱 * */ function checkMail(){ var umail = document.getElementById("email").value; var flag = checkEmail(umail); var span = document.getElementById("span_email"); //对邮箱输入进行校验 if(flag){ span.innerHTML = "<font color='red' size='2'>恭喜您,可用</font>"; return true; }else{ span.innerHTML = "<font color='red' size='2'>对不起,邮箱格式貌似有问题</font>"; return false; } } function checkForm(){ var flag = checkUsername() && checkPassword() && checkRePassword() && checkMail(); return flag; } </script> </head> <body> <form action="../01-自动轮播图片/图片自动轮播.html" onsubmit="return checkForm()" > 用户名:<input type="text" id="username" onfocus="showTips('span_username','用户名长度不能小于6')" onblur="checkUsername()" onkeyup="checkUsername()" /><span id="span_username"></span><br /> 密码:<input type="password" id="password" onfocus="showTips('span_password','密码长度不能小于6')" onblur="checkPassword()" onkeyup="checkPassword()"/><span id="span_password"></span><br /> 确认密码:<input type="password" id="repassword" onfocus="showTips('span_repassword','两次密码必须一致')" onblur="checkRePassword()" onkeyup="checkRePassword()" /><span id="span_repassword"></span><br /> 邮箱:<input type="text" id="email" onfocus="showTips('span_email','邮箱格式必须正确')" onblur="checkMail()" /><span id="span_email"></span><br /> 手机号:<input type="text" id="text" /><br /> <input type="submit" value="提交" /> </form> </body> </html>
定时器:
setInterval("test()",3000) 每隔多少毫秒执行一次函数
setTimeout("test()",3000) 多少毫秒以后执行一次函数
timerID 上面定时器调用以后
clearInterval()
clearTimeout()
切换图片
img.src = "图片路径"
事件: 文档加载完成的事件 onload事件
显示广告 : img.style.display = "block"
隐藏广告: img.style.display ="none"
引入一个外部js文件
<script src="js文件的路径" type="text/javascript"/>
表单校验中经常使用的事件:
得到焦点事件: onfocus
失去焦点事件 onblur
按键抬起事件: onkeyup
JS开发步骤
1. 肯定事件 2. 事件要触发函数: 定义函数 3. 函数一般都要去作一些交互: 点击, 修改图片, 动态修改innerHTML属性... innerTEXT
咱们商品分类的信息太多,若是每一行都显示同一个颜色的话会让人看的眼花,为了提升用户体验,减小用户看错的状况,须要对表格进行隔行换色
改变行的颜色
肯定事件: 文档加载完成 onload
事件要触发函数: init()
<script > function init(){ //获得表格 var tab = document.getElementById("tab"); //获得表格中每一行 var rows = tab.rows; //便利全部的行,而后根据奇数 偶数 for(var i=1; i < rows.length; i++){ var row = rows[i]; //获得其中的某一行 if(i%2==0){ row.bgColor = "yellow"; }else{ row.bgColor = "red" } } } </script>
商品分类界面中,当咱们点击全选框的时候,咱们但愿选中全部的商品,当咱们取消掉的时候,咱们但愿不选中全部的商品
事件 : onclick点击事件
全选和全不选步骤分析:
1.肯定事件: onclick 单机事件
2.事件触发函数: checkAll()
3.函数要去作一些事情:
得到当前第一个checkbox的状态 得到全部分类项的checkbox 修改每个checkbox的状态
function checkAll(){ // 得到当前第一个checkbox的状态 var check1 = document.getElementById("check1"); //获得当前checked状态 var checked = check1.checked; // 得到全部分类项的checkbox // var checks = document.getElementsByTagName("input"); var checks = document.getElementsByName("checkone"); // alert(checks.length); for(var i = 0; i < checks.length; i++){ // 修改每个checkbox的状态 var checkone = checks[i]; checkone.checked = checked; } }
什么是DOM: Document Object Model : 管理咱们的文档 增删改查规则
【HTML中的DOM操做】
一些经常使用的 HTML DOM 方法: getElementById(id) - 获取带有指定 id 的节点(元素) appendChild(node) - 插入新的子节点(元素) removeChild(node) - 删除子节点(元素) 一些经常使用的 HTML DOM 属性: innerHTML - 节点(元素)的文本值 parentNode - 节点(元素)的父节点 childNodes - 节点(元素)的子节点 attributes - 节点(元素)的属性节点 查找节点: getElementById() 返回带有指定 ID 的元素。 getElementsByTagName() 返回包含带有指定标签名称的全部元素的节点列表(集合/节点数组)。 getElementsByClassName() 返回包含带有指定类名的全部元素的节点列表。 增长节点: createAttribute() 建立属性节点。 createElement() 建立元素节点。 createTextNode() 建立文本节点。 insertBefore() 在指定的子节点前面插入新的子节点。 appendChild() 把新的子节点添加到指定节点。 删除节点: removeChild() 删除子节点。 replaceChild() 替换子节点。 修改节点: setAttribute() 修改属性 setAttributeNode() 修改属性节点
在咱们的分类管理中,咱们要可以去修改咱们的分类信息,当咱们一点修改的时候,跳转到一个能够编辑的页面,这里面可以修改分类的名称,分类的描述,以及分类的商品
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <!-- 步骤分析 1. 肯定事件: 点击事件 :onclick事件 2. 事件要触发函数 selectOne 3. selectOne要作一些操做 (将左边选中的元素移动到右边的select中) 1. 获取左边Select中被选中的元素 2. 将选中的元素添加到右边的Select中就能够 --> <script> function selectOne(){ // 1. 获取左边Select中被选中的元素 var leftSelect = document.getElementById("leftSelect"); var options = leftSelect.options; //找到右侧的Select var rightSelect = document.getElementById("rightSelect"); //遍历找出被选中的option for(var i=0; i < options.length; i++){ var option1 = options[i]; if(option1.selected){ // 2. 将选中的元素添加到右边的Select中就能够 rightSelect.appendChild(option1); } } } //将左边全部的商品移动到右边 function selectAll(){ // 1. 获取左边Select中被选中的元素 var leftSelect = document.getElementById("leftSelect"); var options = leftSelect.options; //找到右侧的Select var rightSelect = document.getElementById("rightSelect"); //遍历找出被选中的option for(var i=options.length - 1; i >=0; i--){ var option1 = options[i]; rightSelect.appendChild(option1); } } </script> </head> <body> <table border="1px" width="400px"> <tr> <td>分类名称</td> <td><input type="text" value="手机数码"/></td> </tr> <tr> <td>分类描述</td> <td><input type="text" value="这里面都是手机数码"/></td> </tr> <tr> <td>分类商品</td> <td> <!--左边--> <div style="float: left;"> 已有商品<br /> <select multiple="multiple" id="leftSelect" ondblclick="selectOne()"> <option>华为</option> <option>小米</option> <option>锤子</option> <option>oppo</option> </select> <br /> <a href="#" onclick="selectOne()"> >> </a> <br /> <a href="#" onclick="selectAll()"> >>> </a> </div> <!--右边--> <div style="float: right;"> 未有商品<br /> <select multiple="multiple" id="rightSelect"> <option>苹果6</option> <option>肾7</option> <option>诺基亚</option> <option>波导</option> </select> <br /> <a href="#"> << </a> <br /> <a href="#"> <<< </a> </div> </td> </tr> <tr> <td colspan="2"> <input type="submit" value="提交"/> </td> </tr> </table> </body> </html>
今天内容简单回顾:
定时器:
setInterval
setTimeout
clearInterval
clearTimeout
控制图片显示隐藏
img.style.display = "block"
img.style.display = "none"
表单中经常使用的事件:
onfocus: 获取焦点事件
onblur : 失去焦点的事件
onkeyup: 按键抬起的事件
onclick: 单击事件
ondblclick: 双击事件
表格隔行换色,鼠标移入和移除要变色:
onmouseenter: 鼠标移入
onmouseout: 鼠标移出
onload: 文档加载完成事件
onsubmit: 提交
onchange: 下拉列表内容改变
checkbox.checked 选中状态
DOM的文档操做:
添加节点: appendChild
建立节点: document.createElement
建立文本节点: document.createTextNode()
JS开发步骤:
1. 确认事件 2. 事件触发函数 3. 函数里面要作一些交互