算法简介 冒泡排序是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序不符合要求就把它们交换过来。...时间复杂度和空间复杂度 再谈谈冒泡排序的时间复杂度和空间复杂度吧!
什么是冒泡? DOM事件流(event flow )存在三个阶段:事件捕获阶段、处于目标阶段、事件冒泡阶段。...事件冒泡**(***dubbed bubbling***)**:与事件捕获恰恰相反,事件冒泡顺序是由内到外进行事件传播,直到根节点。...dom标准事件流的触发的先后顺序为:先捕获再冒泡,即当触发dom事件时,会先进行事件捕获,捕获到事件源之后通过事件传播进行事件冒泡。...参数 useCapture 是选填的,填true或者false,用于描述事件是冒泡还是捕获,true表示捕获,默认的false表示冒泡。...") }); div2.addEventListener('click',function(){ console.log("div2--冒泡阶段"
冒泡排序: 冒泡排序是一种简单的排序算法。 它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。
console.log(num);//10 console.log(obj1.item);//changed console.log(obj2.item);//unchanged 相反,情况是传入的项是按值传递的...但是通过值传递的项本身就是一个引用。从技术上讲,这叫做call_by_sharing。 实际上,这意味着如果更改参数本身(如num和obj2),则不会影响传入参数的项。
停止事件传播 事件对象还提供了一个.stopPropagation()方法,该方法能够全然阻止事件冒泡。
Js函数里面的参数 在看 Js参数传递时,先看最基本的,会为下面做铺垫 function fn() { var a = 100 console.log(a); //100 } fn()...console.log(a); //100 a = 100 console.log(a); //100 } fn(100) console.log(a); //报错a is not defined Js...参数传递 在这里,直接通过具体案例一个个循环渐进的说明 js的参数传递 普通类型参数传递 首先就是最简单的普通类型(string,number,boolean,null,undefined,symbol...*/ 引用数据类型参数传递 案例1: var a = { age: 1 } a = { age: 100 } console.log(a); //{age:100} 案例2: var a = { age
function viewportToPixels(value) { var parts = value.match(/([0-9.]+)(vh|vw)/...
// 冒泡排序 var arr = [2, 4, 1, 6, 7, 8, 33, 11,77,88,99,3,100]; function sort(array
事件冒泡及阻止 当一个元素接收到事件的时候,会把他接收到的事件传给自己的父级,一直到window,当然其传播的是事件,绑定的执行函数并不会传播,如果父级没有绑定事件函数,就算传递了事件,也不会有什么表现...,但事件确实传递了。...DOCTYPE html> JS事件冒泡及阻止 div{...DOCTYPE html> JS事件冒泡及阻止 li{...注意 不是所有的事件都能冒泡。以下事件不冒泡:blur、focus、load、unload。 事件解决方案方式在不同浏览器,可能是有所区别的,有些不支持捕获型方案,多数浏览器默认冒泡型方案。
——达·芬奇 js禁止右键点击事件触发代码 function click() { return false; } function click1() { if (event.button
禁止右键菜单代码、禁止复制粘贴代码 //屏蔽右键菜单 document.oncontextmenu
相反的,事件冒泡是自下而上的去触发事件。绑定事件方法的第三个参数,就是控制事件触发顺序是否为事件捕获。true,事件捕获;false,事件冒泡。默认false,即事件冒泡。...Jquery的e.stopPropagation会阻止冒泡,意思就是到我为止,我的爹和祖宗的事件就不要触发了。...事件的触发顺序自内向外,这就是事件冒泡。...方法: 阻止事件冒泡 和默认行为。 事件冒泡: ? 阻止默认行为: ?
事件机制 ---- 事件触发三个阶段: window往事件触发处传播,遇到注册的捕获事件会触发 传播到事件触发处时触发注册的事件 从事件触发处往window传播,遇到注册的冒泡事件会触发 事件触发一般会按照...|------------------------------------------- 但是有一个特例:如果给body中的子节点同时注册冒泡和捕获事件,事件触发会按照注册的顺序执行。...// 以下会先打印冒泡然后是捕获node.addEventListener( 'click', event => { console.log('冒泡') }, false)node.addEventListener...此时进入冒泡阶段,inner上的时间处理器得到执行 事件命中元素后开始向上冒泡,一路查找是否注册了冒泡阶段的祖先元素上的时间处理器。由于没有找到因此什么也没发生。...我们把时间注册在冒泡阶段(addEventListener的useCapture选项为false) var selector = document.querySelector.bind(document
正题 ECMAScript 中所有函数的参数都是按值传递的。访问变量有按值和按引用两种方式,而参数只能按值传递。 基本类型参数传递:传给函数的是数值的一个复制,函数中对其的修改外部不可见。...//2 console.log(b); //1 } change(a, b); console.log(a); //1 console.log(b); //2 引用类型参数传递...4,2,3" } change(a,b); console.log(a); //"4,2,3" console.log(b); //"5,6" a,b是change函数中的变量,在调用函数时传递了...= b; //用新引用覆盖 b = c; } change(a,b); console.log(a); //"5,6" console.log(b); //"4,2,3" 因为js
事件冒泡: 事件冒泡由IE团队提出来的,即事件开始由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播。...IE9,chrome,Firefox,Opera,Safari都支持事件冒泡,并将事件冒泡到window对象。 如下,点击obj3,依次弹出obj3、world、hello。...addEventListener('click', function () { alert('obj3'); })//依次弹出obj3、world、hello 阻止事件冒泡的方法...: 方式一:event.stopPropagation(); 方式二:return false; return false 不仅阻止了事件往上冒泡,而且阻止了事件本身。...event.stopPropagation() 则只阻止事件往上冒泡,不阻止事件本身。
08.19自我总结 js|jq获取兄弟节点,父节点,子节点 一.js var parent = test.parentNode; // 父节点 var chils = test.childNodes;...test.previousElementSibling; // 上一个兄弟节点元素 var next = test.nextElementSibling; // 下一个兄弟节点元素 注意操作父来控制子必须给子元素赋予一个变量 二.jq
System.out.println(string); } return ; } 注:两种post请求的content-type不同 未经允许不得转载:肥猫博客 » js...传递数组到后台
代码给元素后期添加事件) 事件传递(事件冒泡): 如果某一个位置有多个元素的事件需要响应,响应顺序是从最底层往上层传递(类似气泡),所以也称为事件冒泡 ###DOM Document Object...js对象和jq对象互相转换:(js对象和jq对象不是一个东西,不能互相调用彼此的方法,有些时候只能的js对象但是需要用到jq框架里面的方法这时候就需要使用以下方式将js对象转成jq,同理有时只能得到jq...对象但是需要调用js对象里面的方法,所以需要使用以下方法把jq对象转成js对象) //js获取对象的方式 var js = document.getElementById(“d1”); //jq获取对象的方式...var jq = $("#d1"); js转jq: var jq = $(js); jq转js: var js = jq[0]; ###选择器 基础选择器 用法和css中一样 id选择器 $(...("i1"); //js对象转成jq对象 var jq = $(js); //jq.val() 获取文本框的值 alert(jq.val()); }); $(
Js值传递和引用传递的不同 概念不同 1、值传递为单向传递,只能由实参传递给形参,形参无法改变实参的值。 2、引用类型传递可以通过改变形参而改变实参。...传递的数据类型 3、值传递传递的是一个值。引用传递传递的是一个对象。...(1)值传递 var a = 1; function fn(a){ a ++; return a; } a = 1; console.log(fn(a)); console.log(a); (2)引用传递...obj = new Object(); fn(obj); console.log(Orville's Ideas and Interests); //obj为外部创建的对象所以输出值为“abc” 以上就是Js...值传递和引用传递的不同,希望对大家有所帮助。
js禁止浏览器后退按钮 1.js //禁止浏览器后退按钮 function BanBack(ele) { //禁止浏览器后退按钮 if (window.history && window.history.pushState
领取专属 10元无门槛券
手把手带您无忧上云