javascript网页随机点名实现过程解析


Posted in Javascript onOctober 15, 2019

主要知识点涉及if选择结构判断语句、数组的定义、定时器、清除定时器、日期对象的使用。

1.HTML结构

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>随机点名</title>
  <style type="text/css">
    .box{
      width: 200px;
      height: 200px;
      border: 1px solid red;
    }
    #uname{
      width: 100px;
      height: 50px;
      background: pink;

      /* 设置div块 水平居中*/
      margin: 0 auto;
      margin-top: 30px;
      

      text-align: center; /* 设置文本水平居中 */
      line-height: 50px; /* 设置文本垂直居中 */
      font-weight: bold; /* 字体加粗 */
      font-size: 20px; /* 设置字体大小 */
    }
    button{
      display: block; /* 将元素转换成行内块元素 */
      margin: 10px auto;
    }
  </style>
</head>
<body>

<div class="box">
  <div id="uname">姓名</div>
  <button>开始</button>
</div>

</body>
</html>

页面如下图所示:

javascript网页随机点名实现过程解析

2.js代码

1)在开始按钮和结束按钮之间相互转换

点击 开始 按钮,将按钮中的内容修改为 结束

<body>
<script type="text/javascript">
  // 获取按钮对象
  var btn = document.getElementsByTagName("button")[0];
  // 给按钮添加单击事件
  btn.onclick = function(){
    btn.innerHTML="结束"
  };
</script>
</body>

javascript网页随机点名实现过程解析

点击结束按钮 ,按钮变成开始按钮

切换按钮:判断按钮状态,如果按钮为开始按钮,将按钮变成结束按钮;

如果按钮为结束按钮,将按钮变成开始按钮。

<body>

<script type="text/javascript">
  // 获取按钮对象
  var btn = document.getElementsByTagName("button")[0];
  // 给按钮添加单击事件
  btn.onclick = function(){
    if(btn.innerText=="开始"){
      btn.innerHTML="结束"
    }else{
      btn.innerHTML="开始"
    }
    
  };
</script>
</body>

定义一个数组用来存储人名,点击开始按钮,随机选择人名;

点击停止按钮,页面不再发生变化。

<body>

<div class="box">
  <div id="uname">姓名</div>
  <button>开始</button>
</div>
<script type="text/javascript">
  // 定义数组 存储人名
  var arr = ['李白','杜甫','韩愈','柳宗元','欧阳修','苏洵','苏轼','苏辙','王安石','曾巩','陶渊明','辛弃疾','李贺','陆游'];
  // 获取id="uname"的元素对象
  var Uname = document.getElementById("uname");
  var flag = null; // 给定时器添加一个标识符

  // 获取按钮对象
  var btn = document.getElementsByTagName("button")[0];
  // 给按钮添加单击事件
  btn.onclick = function(){
    if(btn.innerText=="开始"){
      btn.innerHTML="结束";
      // 添加多次定时器
      flag = setInterval(function(){
      var num = rand(0,arr.length-1); //随机获取数组的索引
      // 通过索引获取人名
      var uname = arr[num];
      // 将取出来的人名 写入到页面当中
      Uname.innerHTML=uname;
      },100)
      
    }else{
      btn.innerHTML="开始";
      // 清除多次定时器
      clearInterval(flag);
    }
    
  };


  // 封装一个随机函数
  function rand(n,m){
    return Math.floor(Math.random()*(m-n+1));
  }
</script>
</body>

页面最终显示如下图所示:

javascript网页随机点名实现过程解析

3.innerText( )和innerHTML( )之间的区别

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>Title</title>
</head>
<body>

<p>余生<em>山海</em>远阔,愿你随心所向。</p>
<script type="text/javascript">
  // 获取元素对象
  var cont = document.getElementsByTagName("p")[0];
  // 获取元素内容
  console.log(cont.innerText);
  console.log(cont.innerHTML);
</script>
</body>
</html>

javascript网页随机点名实现过程解析

-------------------------------------------------------------------------------------------

innerText、innerHTML 向指定元素添加内容

innerHTML :设置元素内容,包括标签和文本 一般用于修改元素对象,获取文本内容和标签

innerText:设置元素文本,只能设置文本 一般用于获取元素对象,只能获取到文本内容,

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript笔记 String类replace函数的一些事
Sep 22 Javascript
JS对话框_JS模态对话框showModalDialog用法总结
Jan 11 Javascript
元素未显示设置width/height时IE中使用currentStyle获取为auto
May 04 Javascript
10分钟学会写Jquery插件实例教程
Sep 06 Javascript
javascript实现根据3原色制作颜色选择器的方法
Jul 17 Javascript
javascript数组克隆简单实现方法
Dec 16 Javascript
vue双向绑定的简单实现
Dec 22 Javascript
JScript实现地址选择功能
Aug 15 Javascript
vue-自定义组件传值的实例讲解
Sep 18 Javascript
原生JS实现的自动轮播图功能详解
Dec 28 Javascript
Vue+Node服务器查询Mongo数据库及页面数据传递操作实例分析
Dec 20 Javascript
JS使用正则表达式实现常用的表单验证功能分析
Apr 30 Javascript
javascript随机变色实例代码
Oct 15 #Javascript
vue中axios的二次封装实例讲解
Oct 14 #Javascript
Vue项目打包部署到iis服务器的配置方法
Oct 14 #Javascript
浅析微信小程序modal弹窗关闭默认会执行cancel问题
Oct 14 #Javascript
vue实现百度语音合成的实例讲解
Oct 14 #Javascript
vue中进行微博分享的实例讲解
Oct 14 #Javascript
深入理解基于vue-cli的webpack打包优化实践及探索
Oct 14 #Javascript
You might like
jQuery阻止冒泡和HTML默认操作
2010/11/17 Javascript
Jquery插件 easyUI属性汇总
2011/01/19 Javascript
js 完美图片新闻轮转效果,腾讯大粤网首页图片轮转改造而来
2011/11/21 Javascript
js中top/parent/frame概述及案例应用
2013/02/06 Javascript
JavaScript DOM操作表格及样式
2015/04/13 Javascript
Vue开发过程中遇到的疑惑知识点总结
2017/01/20 Javascript
性能优化之代码优化页面加载速度
2017/03/01 Javascript
Bootstrap缩略图的创建方法
2017/03/22 Javascript
Angular使用操作事件指令ng-click传多个参数示例
2018/03/27 Javascript
使用Vue的slot插槽分发父组件内容实现高度复用、更加灵活的组件(推荐)
2018/05/01 Javascript
webpack打包react项目的实现方法
2018/06/21 Javascript
Angularjs中的$apply及优化使用详解
2018/07/02 Javascript
解决jquery的ajax调取后端数据成功却渲染失败的问题
2018/08/08 jQuery
JS变量提升原理与用法实例浅析
2020/05/22 Javascript
解决Vue中的生命周期beforeDestory不触发的问题
2020/07/21 Javascript
通过JS判断网页是否为手机打开
2020/10/28 Javascript
python文件名和文件路径操作实例
2017/09/29 Python
python pandas中DataFrame类型数据操作函数的方法
2018/04/08 Python
Pandas之drop_duplicates:去除重复项方法
2018/04/18 Python
用xpath获取指定标签下的所有text的实例
2019/01/02 Python
浅析python redis的连接及相关操作
2019/11/07 Python
python实现取余操作的简单实例
2020/08/16 Python
python七种方法判断字符串是否包含子串
2020/08/18 Python
python3中布局背景颜色代码分析
2020/12/01 Python
AmazeUI 单选框和多选框的实现示例
2020/08/18 HTML / CSS
欧迪办公美国官网:Office Depot
2016/08/22 全球购物
英国鞋类及配饰零售商:Kurt Geiger
2017/02/04 全球购物
Nordgreen美国官网:在线购买极简主义斯堪的纳维亚手表
2019/07/24 全球购物
英国DIY和家居装饰领域的主要品牌:Wickes
2019/11/26 全球购物
《春雨》教学反思
2014/04/24 职场文书
青年志愿者活动总结
2014/04/26 职场文书
2015年元旦活动总结
2014/05/09 职场文书
关于运动会的广播稿(10篇)
2014/09/12 职场文书
公司法定代表人授权委托书
2014/09/29 职场文书
2015年高校教师个人工作总结
2015/05/25 职场文书
如何书写邀请函?
2019/06/24 职场文书