1、javascript:void(0)

javascript:void(0)表示不做任何动作

Javascript中void是一个操作符,该操作符指定要计算一个表达式但是不返回值。

  1. <a href="javascript:void(0);" onclick="alert('ok');"></a>
  2. // 这里表示这个链接不做跳转动作,执行onClick事件。
(1)void 操作符用法格式如下
  1. javascript:void (expression)

  2. javascript:void expression

expression 是一个要计算的 Javascript 标准的表达式。

下面的代码创建了一个超级链接,用户单时会提交表单

  1. <a HREF="javascript:void(document.form.submit())">单此处提交表单</a>
(2)a href=#与 a href=javascript:void(0) 的区别链接的几种办法

#包含了一个位置信息

默认的锚点是#top 也就是网页的上端

而javascript:void(0)   仅仅表示一个死链接

这就是为什么有的时候页面很长浏览链接明明是#是

跳动到了页首

而javascript:void(0) 则不是如此

所以调用脚本的时候最好用void(0)或者<input onclick>、<div onclick>等

2、函数

(1) arguments.length

arguments.length 属性返回函数接收到参数的个数

  1. 2a href=#与 a href=javascript:void(0) 的区别链接的几种办法
  2.  
  3. #包含了一个位置信息
  4.  
  5. 默认的锚点是#top 也就是网页的上端
  6.  
  7. javascript:void(0) 仅仅表示一个死链接
  8.  
  9. 这就是为什么有的时候页面很长浏览链接明明是#是
  10.  
  11. 跳动到了页首
  12.  
  13. javascript:void(0) 则不是如此
  14.  
  15. 所以调用脚本的时候最好用void(0)或者<input onclick>、<div onclick>等
  16.  
  17. 2、函数
  18.  
  19. (1) arguments.length
  20.  
  21. arguments.length 属性返回函数接收到参数的个数
(2) toString()

toString() 方法将函数作为一个字符串返回

  1. <script>
  2. function myFunction(a, b) {
  3. return a * b;
  4. }
  5. document.getElementById("demo").innerHTML = myFunction.toString();
  6. </script>
(3) 函数表达式的自调用

函数表达式可以 "自调用"。

自调用表达式会自动调用。

如果表达式后面紧跟 () ,则会自动调用。

不能自调用声明的函数。

通过添加括号,来说明它是一个函数表达式:

  1. <script>
  2. (function () {
  3. document.getElementById("demo").innerHTML = "Hello! 我是自己调用的";
  4. })();
  5. </script>

4、对象

(1) arguments

这个函数体内的arguments非常特殊,实际上是所在函数的一个内置类数组对象,可以用数组的[i]和.length。

js语法不支持重载!但可用arguments对象模拟重载效果。

arguments对象:函数对象内,自动创建的专门接收所有参数值的类数组对象。 arguments[i]: 获得传入的下标为i的参数值 arguments.length: 获得传入的参数个数!

重载:

  程序中可定义多个相同函数名,不同参数列表的函数,   调用者不必区分每个函数的参数,   执行时,程序根据传入的参数个数,自动判断选择哪个函数执行。

  1. //1、如果用户传入一个参数,求平方
  2. function sum(a){
  3. console.log(a*a);
  4. }
  5.  
  6. //如果用户传入两个参数,就求和
  7. function sum(a,b){
  8. console.log(a+b);
  9. }
  10. sum(4); //?
  11. sum(4,5); //?

上述例子中本意是想让同名函数sum()根据参数不同输出不同结果,但是sum是函数名字,本质也是个变量,第二个会覆盖第一个,所以上述的正确输出答案是:NaN,9.所以这样显然不可以。

如果用arguments,就简单多了。

  1. //2、
  2. function calc(){
  3. //如果用户传入一个参数,求平方
  4. if(arguments.length==1){
  5. console.log(arguments[0]*arguments[0]);
  6. }else if(arguments.length==2){
  7. //如果用户传入两个参数,就求和
  8. console.log(arguments[0]+arguments[1]);
  9. }
  10. }
  11. calc(4); //
  12. calc(4,5); //
  13.  
  14. /*3、无论用户传入几个数字,都可以求和*/
  15. function add(){
  16. //arguments:[]
  17. //遍历arguments中每个元素,并累加
  18. for(var i=0,sum=0;i<arguments.length;sum+=arguments[i++]);
  19. return sum;//返回和
  20. }
  21.  
  22. console.log(add(1,2,3)); //
  23. console.log(add(1,2,3,4,5,6)); //
python 中为什么不需要重载

函数重载主要是为了解决两个问题。

(1)可变参数类型。

(2) 可变参数个数。

另外,一个基本的设计原则是,仅仅当两个函数除了参数类型和参数个数不同以外,其功能是完全相同的,此时才使用函数重载,如果两个函数的功能其实不同,那么不应当使用重载,而应当使用一个名字不同的函数。

好吧,那么对于情况 (1),函数功能相同,但是参数类型不同,python 如何处理?答案是根本不需要处理,因为 python 可以接受任何类型的参数,如果函数的功能相同,那么不同的参数类型在 python 中很可能是相同的代码,没有必要做成两个不同函数。

那么对于情况 (2),函数功能相同,但参数个数不同,python 如何处理?答案就是缺省参数。对那些缺少的参数设定为缺省参数即可解决问题。因为你假设函数功能相同,那么那些缺少的参数终归是需要用的。

好了,鉴于情况 (1) 跟 情况 (2) 都有了解决方案,python 自然就不需要函数重载了。

这里顺便说一下python中参数传递时候的*arg和**args,看几个小栗子就一清二楚了:

第一个小栗子:

  1. def test1(farg,*args):
  2. print ("farg:",farg)
  3. for value in args:
  4. print ("args:",value)
  5.  
  6. test1(1,"two",3,"")

5、闭包

  1. var add = (function () {
  2. var counter = 0;
  3. return function () {return counter += 1;}
  4. })();
  5. function myFunction(){
  6. document.getElementById("demo").innerHTML = add();
  7. }
  8.  
  9. add();
  10. add();
  11. add();
  12.  
  13. // 计数器为 3

变量 add 指定了函数自我调用的返回字值。

自我调用函数只执行一次。设置计数器为 0。并返回函数表达式。

add变量可以作为一个函数使用。非常棒的部分是它可以访问函数上一层作用域的计数器

这个叫作 JavaScript 闭包。它使得函数拥有私有变量变成可能。

计数器受匿名函数的作用域保护,只能通过 add 方法修改。

6、js查找HTML元素的方式、方法

一、HTMLCollection(document.getElement....)

二、NodeList(querySelectorAll (......))

三、二者的区别和共同点

HTMLCollection是 HTML 元素的集合。

NodeList 是一个文档节点的集合。

NodeList 与 HTMLCollection 有很多类似的地方。

NodeList 与 HTMLCollection 都与数组对象有点类似,可以使用索引 (0, 1, 2, 3, 4, ...) 来获取元素。

NodeList 与 HTMLCollection 都有 length 属性。

HTMLCollection 元素可以通过 name,id 或索引来获取。

NodeList 只能通过索引来获取。

只有 NodeList 对象有包含属性节点和文本节点。

注意:节点列表不是一个数组!

节点列表看起来可能是一个数组,但其实不是。

你可以像数组一样,使用索引来获取元素。

节点列表无法使用数组的方法: valueOf(), pop(), push(), 或 join() 。

(1)通过id

通过id可以直接操作标签(原因是id唯一)

  1. <p id="p1">Hello World!</p>
  2. <script>
  3. document.getElementById("p1").innerHTML="新文本!";
  4. </script>

以下两种不行,每个类名、标签都可能不唯一,在操作的时候需要注明是第几个标签

(2)通过classname
  1. <p class="p1">Hello World!</p>
  2. <script>
  3. document.getElementsByClassName("p1")[0].innerHTML="新文本!";
  4. // 注意:在此操作的时候必须指明(只有一个也必须标明),虽然不会报错,但是看不到执行效果
  5. </script>
(3)通过tag标签(与classname类似)
  1. <p id="p1">Hello World!</p>
  2. <script>
  3. document.getElementsByTagName("p")[0].innerHTML="新文本!";
  4. </script>
  5. <p>以上段落通过脚本修改文本。</p>

7、标签操作

(1)添加节点

在之前添加

  1. var para = document.createElement("p");
  2. var node = document.createTextNode("这是一个新的段落。");
  3. para.appendChild(node);
  4.  
  5. var element = document.getElementById("div1");
  6. var child = document.getElementById("p1");
  7. element.insertBefore(para, child);

在之后添加(默认)

  1. var para = document.createElement("p");
  2. var node = document.createTextNode("这是一个新的段落。");
  3. para.appendChild(node);
  4.  
  5. var element = document.getElementById("div1");
  6. element.appendChild(para);
(2)删除节点

必须通过父节点进行删除当前节点,两种方式

① 直接找到父节点
  1. var parent = document.getElementById("div1");
  2. var child = document.getElementById("p1");
  3. parent.removeChild(child);

② 通过子节点的父级来删除

  1. var child = document.getElementById("p1");
  2. child.parentNode.removeChild(child);
(3)替换
  1. var para = document.createElement("p");
  2. var node = document.createTextNode("这是一个新的段落。");
  3. para.appendChild(node);
  4.  
  5. var parent = document.getElementById("div1");
  6. var child = document.getElementById("p1");
  7. parent.replaceChild(para, child);
  8. //para 替换child

8、数字

无限

  1. myNumber=2;
  2. while (myNumber!=Infinity){
  3. myNumber=myNumber*myNumber;
  4. document.write(myNumber +'<BR>');
  5. }
  6.  
  7. var x = 2/0;
  8. var y = -2/0;
  9. document.write(x + "<br>");
  10. document.write(y + "<br>");

NaN

其中无穷大是数字

  1. <p>一个数字除以一个字符串结果不是一个数字</p>
  2. <p>一个数字除以一个字符串数字结果是一个数字</p>
  3. <p id="demo"></p>
  4. <script>
  5. var x = 1000 / "Apple";
  6. var y = 1000 / "1000";
  7. document.getElementById("demo").innerHTML = isNaN(x) + "<br>" + isNaN(y);
  8. </script>

数字可以是数字,也可以是数字对象

9、字符串

string.length   字符串长度

替换:后面的替换前面的

  1. <p>替换 "Microsoft" 为 "Runoob" :</p>
  2. <button onclick="myFunction()">点我</button>
  3. <p id="demo">请访问 Microsoft!</p>
  4. <script>
  5. function myFunction() {
  6. var str = document.getElementById("demo").innerHTML;
  7. var txt = str.replace("Microsoft","Runoob");
  8. document.getElementById("demo").innerHTML = txt;
  9. }
  10. </script>

内容匹配:

match()函数用来查找字符串中特定的字符,并且如果找到的话,则返回这个字符。

str.split(",") 按,分割

10、日期对象

  1. //获取当前日期
  2. var d=new Date();
  3. d.getFullYear();//获取年份
  4. d.getTime();//返回的是1970/01/01至今的毫秒数
  5. d.setFullYear(2020,10,3);//设置具体的日期时间
  6. d.getDay()//显示今天周几,返回的是一个数字
  7. d.getDate();//显示今天是一个月中的哪一天,返回的是一个数字

在网页上显示一个钟表

  1. <script>
  2. function startTime(){
  3. var today=new Date();
  4. var h=today.getHours();
  5. var m=today.getMinutes();
  6. var s=today.getSeconds();// 在小于10的数字前加一个‘0’
  7. m=checkTime(m);
  8. s=checkTime(s);
  9. document.getElementById('txt').innerHTML=h+":"+m+":"+s;
  10. t=setTimeout(function(){startTime()},500);
  11. }
  12. function checkTime(i){
  13. if (i<10){
  14. i="0" + i;
  15. }
  16. return i;
  17. }
  18. </script>
  19. </head>
  20. <body onload="startTime()">
  21.  
  22. <div id="txt"></div>

创建时间实例

  1. new Date() // 当前日期和时间
  2. new Date(milliseconds) //返回从 1970 年 1 月 1 日至今的毫秒数
  3. new Date(dateString)
  4. new Date(year, month, day, hours, minutes, seconds, milliseconds)
  5.  
  6. var today = new Date()
  7. var d1 = new Date("October 13, 1975 11:13:00")
  8. var d2 = new Date(79,5,24)
  9. var d3 = new Date(79,5,24,11,33,0)
  10.  
  11. // 设置一个特定的日期 (2010 年 1 月 14 日):
  12. var myDate=new Date();
  13. myDate.setFullYear(2010,0,14);
  14.  
  15. // 设置5天后的日期
  16. var myDate=new Date();
  17. myDate.setDate(myDate.getDate()+5);
  18.  
  19. // 两个日期进行比较
  20. var x=new Date();
  21. x.setFullYear(2100,0,14);
  22. var today = new Date();
  23.  
  24. if (x>today)
  25. {
  26. alert("今天是2100年1月14日之前");
  27. }
  28. else
  29. {
  30. alert("今天是2100年1月14日之后");
  31. }

11、数组对象

数组对象是使用单独的变量名来存储一系列的值。

数组的操作

  1. // 合并
  2. var hege = ["Cecilie", "Lone"];
  3. var stale = ["Emil", "Tobias", "Linus"];
  4. var children = hege.concat(stale);
  5.  
  6. // 连接字符串
  7. function myFunction(){
  8. var fruits = ["Banana", "Orange", "Apple", "Mango"];
  9. var x=document.getElementById("demo");
  10. x.innerHTML=fruits.join();
  11. }
  12.  
  13. // 删除最后一个
  14. var fruits = ["Banana", "Orange", "Apple", "Mango"];
  15. function myFunction(){
  16. fruits.pop();
  17. var x=document.getElementById("demo");
  18. x.innerHTML=fruits;
  19. }
  20.  
  21. // 追加
  22. var fruits = ["Banana", "Orange", "Apple", "Mango"];
  23. function myFunction(){
  24. fruits.push("Kiwi")
  25. var x=document.getElementById("demo");
  26. x.innerHTML=fruits;
  27. }
  28.  
  29. //反转
  30. fruits.reverse();
  31.  
  32. //删除第一个
  33. fruits.shift();
  34.  
  35. // 截取1到3,左闭右开
  36. fruits.slice(1,3);
  37.  
  38. // 数组排序,默认升序
  39. fruits.sort();
  40.  
  41. //=====================================================================================
  42. //数字排序
  43. function myFunction(){
  44. var points = [40,100,1,5,25,10];
  45. points.sort(function(a,b){return a-b});
  46. var x=document.getElementById("demo");
  47. x.innerHTML=points;
  48. }
  49.  
  50. //数字降序
  51. function myFunction(){
  52. var points = [40,100,1,5,25,10];
  53. points.sort(function(a,b){return b-a});
  54. var x=document.getElementById("demo");
  55. x.innerHTML=points;
  56. }
  57.  
  58. // 在第二个位置添加
  59. function myFunction(){
  60. var fruits = ["Banana", "Orange", "Apple", "Mango"];
  61. fruits.splice(2,0,"Lemon","Kiwi");
  62. var x=document.getElementById("demo");
  63. x.innerHTML=fruits;
  64. }
  65. //=====================================================================================
  66. // 转换成字符串
  67. fruits.toString();
  68.  
  69. // 开头添加
  70. fruits.unshift("Lemon","Pineapple");

12、布尔对象

  1. 如果布尔对象无初始值或者其值为:
  2. 0
  3. -0
  4. null
  5. ""
  6. false
  7. undefined
  8. NaN
  9. 那么对象的值为 false。否则,其值为 true(即使当变量值为字符串 "false" 时)!

13、windows窗口检测

可以打开,关闭一个窗口,并且获取这个窗口的状态

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>菜鸟教程(runoob.com)</title>
  6. <script>
  7. var myWindow;
  8. function openWin(){
  9. myWindow=window.open("","","width=400,height=200");
  10. }
  11. function closeWin(){
  12. if (myWindow){
  13. myWindow.close();
  14. }
  15. }
  16. function checkWin(){
  17. if (!myWindow){
  18. document.getElementById("msg").innerHTML="我的窗口没有被打开!";
  19. }
  20. else{
  21. if (myWindow.closed){
  22. document.getElementById("msg").innerHTML="我的窗口被关闭!";
  23. }
  24. else{
  25. document.getElementById("msg").innerHTML="我的窗口没有被关闭!";
  26. }
  27. }
  28. }
  29. </script>
  30. </head>
  31. <body>
  32.  
  33. <input type="button" value="打开我的窗口" onclick="openWin()" />
  34. <input type="button" value="关闭我的窗口" onclick="closeWin()" />
  35. <br><br>
  36. <input type="button" value="我的窗口被关闭了吗?" onclick="checkWin()" />
  37. <br><br>
  38. <div id="msg"></div>
  39.  
  40. </body>
  41. </html>

javascript相关基础的更多相关文章

  1. JavaScript相关基础知识点

    JavaScript简介: JavaScript是脚本语言,是一种轻量级的编程语言,是可插入 HTML 页面的编程代码,插入 HTML 页面后,可由所有的现代浏览器执行. JavaScript使用: ...

  2. 【前端童鞋看过来!】给大家分享网盘里前端相关书籍,主要是和网络通信(HTTP/TCP/IP)及javascript相关的

    百度云链接:https://pan.baidu.com/s/1kUPdf5H(无密码) 截图: <HTTP权威指南> [豆瓣书评]:此书第一部分是HTTP的概略,如果你没有时间,通读第一部 ...

  3. 三丶JavaScript 的基础学习(一)

      知识预览 BOM对象 DOM对象(DHTML) 8 实例练习 JavaScript概述 JavaScript的历史 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言 ...

  4. 快速掌握JavaScript面试基础知识(三)

    译者按: 总结了大量JavaScript基本知识点,很有用! 原文: The Definitive JavaScript Handbook for your next developer interv ...

  5. javaScript系列 [01]-javaScript函数基础

    [01]-javaScript函数基础 1.1 函数的创建和结构 函数的定义:函数是JavaScript的基础模块单元,包含一组语句,用于代码复用.信息隐蔽和组合调用. 函数的创建:在javaScri ...

  6. JavaScript的基础学习(一)

    一.JavaScript概述 JavaScript的历史 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言(最初绑定在CEnvi软件中).后将其改名ScriptEase ...

  7. 【学习笔记】JavaScript的基础学习

    [学习笔记]JavaScript的基础学习 一 变量 1 变量命名规则 Camel 标记法 首字母是小写的,接下来的字母都以大写字符开头.例如: var myTestValue = 0, mySeco ...

  8. javascript的基础知识及面向对象和原型属性

    自己总结一下javascript的基础知识,希望对大家有用,也希望大家来拍砖,毕竟是个人的理解啊 1.1 类型检查:typeof(验证数据类型是:string) var num = 123; cons ...

  9. JavaScript 引擎基础:Shapes 和 Inline Caches

    JavaScript 引擎基础:Shapes 和 Inline Caches hijiangtao ​ 中国科学院大学 计算机应用技术硕士 260 人赞同了该文章 前言:本文也可以被称做 “JavaS ...

随机推荐

  1. Python中的requests模块注意事项

    主要是说requests.post()方法, 参数: url :  这就不解释了 data:  如果传入的是字典类型,则字典在发出请求时会自动编码为表单形式,表单形式会将字典中的键和值进行一些操作: ...

  2. 解决pdf打印预览中遇到特殊字符,导出失败问题

    本博客是自己在学习和工作途中的积累与总结,仅供自己参考,也欢迎大家转载,转载时请注明出处. 由于近日由于pdf中存在特殊字符导致导出失败,主要原因是"&"字符与freema ...

  3. python---django中orm的使用(4)字段,参数(on_delete重点)补充,一对多,一对一,多对多

    1.索引: 普通索引:加快查找速度 唯一索引:加快查找速度,唯一约束 主键索引:加快查找速度,唯一索引,不为空 class UserInfo(models.Model): username = mod ...

  4. 利用CSS3实现简书中点击“喜欢”时的动画

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. 何凯文每日一句打卡||DAY14

  6. js 正则学习小记之匹配字符串字面量

    今天看了第5章几个例子,有点收获,记录下来当作回顾也当作分享. 关于匹配字符串问题,有很多种类型,今天讨论 js 代码里的字符串匹配.(因为我想学完之后写个语法高亮练手,所以用js代码当作例子) va ...

  7. 以python代码解释fork系统调用

    import os print('Process (%s) start...' % os.getpid()) # Only works on Unix/Linux/Mac: pid = os.fork ...

  8. python3 pandas DataFrame常见用法

    df = pandas.read_clipboard() df 获取索引和值 df.index df.values DataFrame的values属性将数据以二维ndarray形式返回,dtype类 ...

  9. LeetCode(13):罗马数字转整数

    Easy! 题目描述: 罗马数字包含以下七种字符:I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写 ...

  10. javaweb笔记七

    过滤器:是一个web中间组件,用于拦截从客户端发送给服务器的请求和响应.当客户端向服务器发出请求时,服务器会查看是否有过滤器和该请求匹配,如果有,则交给过滤器执行,业务操作后,可以将请求继续向目标资源 ...