JavaScript中的this妙用实例分析


Posted in Javascript onMay 09, 2020

本文实例讲述了JavaScript中的this妙用。分享给大家供大家参考,具体如下:

JavaScript关键字this始JS脚本能够根据使用这个关键字的上下文将值传递给函数。

我们先来看如下一个网页,在用户单击链接之后,弹出一个alert框,然后再转到href属性所指的网页

HTML:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>JavaScript中的this妙用</title>
  <script type="text/javascript" src="js/script.js"></script>
</head>
<body>
  <p style="text-algin:center;">
    你好,点击这里去<a id="redirect" href="http://www.mybry.com/obj/store/list.html" rel="external nofollow" >旧物商店</a>
  </p>
</body>
</html>

JS:

window.onload = initAll;
function initAll(){
  document.getElementById("redirect").onclick = initRedirect;
}
function initRedirect(){
  alert("这是我创建的旧物商城,欢迎访问!");
  window.location = this;
  return false;
}

你可能会主要到,代码中并没有引用特定的网页——这是this关键字的作用之一。this替我们完成的工作之一是从HTML链接获得URL(也就是a标签的href属性)。由于采用这种方式,如果以后脚本改为指向其他的页面而不是旧物商店页面,就不必修改JS。实际上,可以让WEB站点上的所有链接都调用这个相同的JS代码,这一行代码都会自动获得相应的href值。

这样写还有一个好处:如果用户的浏览器不理解JavaScript(比如禁用了JS),那么它只会加载HTML页面,而不显示alert提示,当他们点击链接时,会像一般情况下那样加载页面,不会发生错误,没有任何问题。
我们在来看一个switch/case例子,创建如下页面:

JavaScript中的this妙用实例分析

HTML:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>JavaScript中的this妙用</title>
  <script type="text/javascript" src="js/script.js"></script>
</head>
<body>
  <h2>闲置二手图书</h2>
  <form action="#">
    <input type="button" id="Java" value="Java" />
    <input type="button" id="JavaScript" value="JavaScript" />
    <input type="button" id="MySQL" value="MySQL" />
    <input type="button" id="Html" value="HTML5" />
  </form>
</body>
</html>

JS:

window.onload = initAll;
function initAll(){
  document.getElementById("Java").onclick = viewDetail;
  document.getElementById("JavaScript").onclick = viewDetail;
  document.getElementById("MySQL").onclick = viewDetail;
  document.getElementById("Html").onclick = viewDetail;
}
function viewDetail(){
  console.log("this.id="+this.id);
  switch(this.id){
    case "Java" : 
      alert("《Java程序员基本功》这本书是李刚写的,在我的商店售价30元!");
      break;
    case "JavaScript" : 
      alert("《JavaScript语言精粹》这本书是Yahoo的一位工程师写的,在我的商店售价15元!");
      break;
    case "MySQL" : 
      alert("《MySQL入门很简单》这本书附带关盘,这个年代其实没什么卵用了,它在我的商店售价28元!");
      break;
    case "Html" : 
      alert("《HTML5秘籍》这本书是图灵系统的图书,非常值得拥有,它在我的商店售价25元,卖的非常好!");
      break;
    default : 
      alert("没有这本书");
  }
}

直接用this.id作为switch的参数也是可以的。

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
javascript removeChild 使用注意事项
Apr 11 Javascript
学习ExtJS(一) 之基础前提
Oct 07 Javascript
类似GMAIL的Ajax信息反馈显示
Feb 16 Javascript
JS左右无缝滚动(一般方法+面向对象方法)
Aug 17 Javascript
JavaScript将字符串转换成字符编码列表的方法
Mar 19 Javascript
jQuery点击改变class并toggle及toggleClass()方法定义用法
Dec 11 Javascript
js 打开新页面在屏幕中间的实现方法
Nov 02 Javascript
vue.js事件处理器是什么
Mar 20 Javascript
JavaScript轮播停留效果的实现思路
May 24 Javascript
纯JS实现出生日期[年月日]下拉菜单效果
Jun 01 Javascript
ES6入门教程之let、const的使用方法
Apr 13 Javascript
vue 项目build错误异常的解决方法
Apr 22 Javascript
JavaScript中继承原理与用法实例入门
May 09 #Javascript
jQuery三组基本动画与自定义动画操作实例总结
May 09 #jQuery
JavaScript进阶(四)原型与原型链用法实例分析
May 09 #Javascript
JavaScript进阶(三)闭包原理与用法详解
May 09 #Javascript
JavaScript进阶(二)词法作用域与作用域链实例分析
May 09 #Javascript
JavaScript进阶(一)变量声明提升实例分析
May 09 #Javascript
JavaScript面向对象核心知识与概念归纳整理
May 09 #Javascript
You might like
最贵的咖啡是怎么产生的,它的风味怎么样?
2021/03/04 新手入门
dede3.1分页文字采集过滤规则详说(图文教程)
2007/04/03 PHP
php判断输入不超过mysql的varchar字段的长度范围
2011/06/24 PHP
Javascript 函数对象的多重身份
2009/06/28 Javascript
浅谈jquery点击label触发2次的问题
2016/06/12 Javascript
jQuery实现指定区域外单击关闭指定层的方法【经典】
2016/06/22 Javascript
深入理解Node中的buffer模块
2017/06/03 Javascript
微信小程序 websocket 实现SpringMVC+Spring+Mybatis
2017/08/04 Javascript
vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法
2018/01/25 Javascript
vue-infinite-loading2.0 中文文档详解
2018/04/08 Javascript
使用Vue如何写一个双向数据绑定(面试常见)
2018/04/20 Javascript
关于vue编译版本引入的问题的解决
2018/09/17 Javascript
详解IOS微信上Vue单页面应用JSSDK签名失败解决方案
2018/11/14 Javascript
使用vue for时为什么要key【推荐】
2019/07/11 Javascript
layui自定义插件citySelect实现省市区三级联动选择
2019/07/26 Javascript
Vue如何提升首屏加载速度实例解析
2020/06/25 Javascript
Element Carousel 走马灯的具体实现
2020/07/26 Javascript
[00:23]DOTA2群星共贺开放测试 25日无码时代来袭
2013/09/23 DOTA
Python中的元类编程入门指引
2015/04/15 Python
Python中函数的参数传递与可变长参数介绍
2015/06/30 Python
Python的Twisted框架上手前所必须了解的异步编程思想
2016/05/25 Python
python 每天如何定时启动爬虫任务(实现方法分享)
2018/05/21 Python
python 自定义对象的打印方法
2019/01/12 Python
ipython和python区别详解
2019/06/26 Python
使用python实现名片管理系统
2020/06/18 Python
使用Python解析Chrome浏览器书签的示例
2020/11/13 Python
canvas学习总结三之绘制路径-线段
2019/01/31 HTML / CSS
英国手机壳购买网站:Case Hut
2019/04/11 全球购物
大学生全国两会报告感想
2014/03/17 职场文书
三分钟英语演讲稿
2014/04/24 职场文书
2015年学校食堂工作总结
2015/04/22 职场文书
2015年暑期社会实践总结
2015/07/13 职场文书
会计实训总结范文
2015/08/03 职场文书
2016党员三严三实心得体会
2016/01/15 职场文书
图解上海144收音机
2021/04/22 无线电
零基础学java之带参数以及返回值的方法
2022/04/10 Java/Android