element jQuery JS $(elem).width() border-box: elem.offsetWidth - padding - border content-box: elem.offsetWidth...padding $(elem).innerWidth() elem.clientWidth + scrollbar $(elem).outerWidth() elem.offsetWidth window jQuery...JS $(window).width() document.documentElement.clientWidth $(window).innerWidth() document.documentElement.clientWidth...$(window).outerWidth() window.innerWidth document jQuery JS $(document).width() Math.max(document.body.scrollWidth
1 var common_func; (function() { 2 common_func = { 3 load_hot_data...
什么是函数? * 具有特定功能的n条语句的封装体 * 只有函数是可执行的, 其它类型的数据是不可执行的 * 函数也是对象 2. 为什么要用函数? * 提高代码复用 * 便于阅读和交流 3....如何定义函数? * 函数声明 * 表达式 4. 如何调用(执行)函数?...根据年龄输出对应的信息 2. 如果小于18, 输出: 未成年, 再等等! 3. 如果大于60, 输出: 算了吧! 4. 其它, 输出: 刚好!...什么函数才是回调函数? * 你定义的 * 你没有直接调用 * 但最终它执行了(在特定条件或时刻) 2. 常见的回调函数?...* DOM事件函数 * 定时器函数 * ajax回调函数(后面学) * 生命周期回调函数(后面学) --> //1.
jQuery确实是一个提高前端开发效率的好框架(虽然很多大牛们都说它效率不咋地),但是用好它有时候并不容易,也许你也遇到过以下情况: 一个aspx页面通常可以包含其它ascx控件,如果在多人协同开发的情况下...:程序员小张在控件A.ascx中使用了 $().ready(function{}),而程序员小王又在控件B.ascx中也使用了ready函数,程序员小李在做页面时,把A.ascx,B.ascx都拖到自己的页面中...,然后在页面中也需要用到$().ready函数,这下好了: 虽然jQuery本身的设计还算不错,document加载完成后会依次触发各个ready中定义的function(这一点很好,不象javascript...中默认后面的同名函数会覆盖前面的函数定义),但是如果某个程序员希望自己的ready部分先执行(或者这三个程序员各自的ready处理有严格先后顺序时),这个怎么办呢?...其实这个也不难,可以利用setTimeOut让某个程序员的ready部分延时执行 $().ready(function(){ setTimeout(Test1, 50);//延时50毫秒后再执行本函数
今天我们要说的是结合ES6新特性谈一下js里面的一个很好用的方法-find() 现在的前端和过去的不一样,过去的前端只要会画页面就行了,但是现在仅仅会画页面已经远远不够了,现在前端还需要会处理数据,而且还要会将数据分析分类处理...下面我们讲怎么用前端处理这块的逻辑 首先我们拿到了所有的数据这里我直接放到一个测试用的js里面存放, 要实现之前说的效果,就需要使用我们今天的主角find()方法。 find()是用来做什么的呢?...find()方法返回数组中符合测试函数条件的第一个元素。否则返回undefined 在本文章需要注意的几个点: ①、第一个元素 ②、测试函数 那么如何使用呢?.../find_testcodes.js" type="text/javascript" charset="utf-8"> js/jquery-1.11.2....min.js" type="text/javascript" charset="utf-8">
大家好,又见面了,我是你们的朋友全栈君。 定义:匿名函数顾名思义指的是没有名字的函数,在实际开发中使用的频率非常高!也是学好JS的重点。 匿名函数:没有实际名字的函数。...首先我们声明一个普通函数: //声明一个普通函数,函数的名字叫fn function fn(){ console.log(“张培跃”); } 然后将函数的名字去掉即是匿名函数: //匿名函数...JavaScript中是没有块级作用域的,例如: if(1==1){//条件成立,执行if代码块语句。...在这里简单介绍一下:闭包是可以访问在函数作用域内定义的变量的函数。若要创建一个闭包,往往都需要用到匿名函数。 2、模拟块级作用域,减少全局变量。...执行完匿名函数,存储在内存中相对应的变量会被销毁,从而节省内存。再者,在大型多人开发的项目中,使用块级作用域,会大大降低命名冲突的问题,从而避免产生灾难性的后果。
一、JacaScript动画的基本原理 二、JavaScript中的动画简介 三、常用的动画库 四、动画遇到卡顿的原因及解决方案 (一)卡顿原因 (二)解决方案(优化) ---- 引言——在设计前端页面时...所以电影的帧频为24帧,而电视一般采用的是25帧和30帧两种制式 2、帧:动画中最小单位的单幅影像画面,在讲多少帧的时候指的就是每秒钟画面切换的次数 二、JavaScript中的动画简介 在JavaScript...、常用的动画库 1、Jquery动画: Jqeury对于动画的支持 2、velocity.js/其GitHub地址:完全类似于Jquery语法的动画库 3、Tween JS:支持根据数值对象的属性和...CSS 样式的属性进行补间动画 4、Animo.js:CSS 动画的工具,叠加动画,创建跨浏览器的模糊效果,动画完成后可执行回调函数。...它提供了类似于jQuery的功能(DOM操作、动画、时间、HTTP请求) 和其他功能(集合、日期&数字格式化、日期计算、模板),并有着简单明了的API 8、Rekapi:JavaScript关键帧动画库
分享一个JS封装的运动函数,里面分为弹性运动和缓冲运动两个方法,通过调用startMove()函数来实现动画效果。...obj, attr_in, value_in) }; } } var MOVE_TYPE = { BUFFER: 1, FLEX: 2 }; // 调用运动的函数...,根据不同类型调用不同的方法 function startMove(obj, oTarget, iType, fnCallBack, fnDuring) { var fnMove = null;
可以看看jQuery 1.7 中的源码: // Expose jQuery as an AMD module, but only for AMD loaders that // understand the...( "jquery", [], function() { return jQuery; }); } Require.js中使用jQuery Require.js中使用jQuery.../js", // 第三方脚本模块的别名,jquery比libs/jquery-1.11.1.min.js简洁明了; paths: { "jquery": "libs.../jquery-1.11.1.min.js" } }); // 开始使用jQuery 模块 require(["jquery"], function ($) { //你的代码...); }); Require.js中使用jQuery 插件 虽然jQuery的支持AMD的API, 这并不意味着jQuery插件也是和AMD兼容的。
JS中的高阶函数 高阶函数是指以函数作为参数的函数,并且可以将函数作为结果返回的函数。 1....高阶函数 接受一个或多个函数作为输入 输出一个函数 至少满足以上一个条件的函数 在js的内置对象中同样存在着一些高阶函数,像数组的map,filter,reduce方法等,它们接受一个函数作为参数,并应用这个函数到列表的每一个元素...,这里就不一一说明了,从上面的三个方法中,已经能很直观的感受到了函数接收函数作为参数,再返回值的过程,逼格很高也很好用 2....把一些与业务无关的功能抽离出来,通过"动态植入"的方法,掺入到业务逻辑模块中。...Function.prototype.bind 函数就是一个偏函数的典型代表,它接受的第二个参数开始,为预先添加到绑定函数的参数列表中的参数 4.
一、JS中的Ajax ajax:异步访问/局部刷新 1.同步和异步 2.Ajax的运行原理 页面请求---->Ajax引擎----->提交给服务器端 这段时间可以做任何事情 服务器端响应------...>Ajax引擎----->触发设置好的事件,执行自定义的js逻辑代码,然后显示页面 js改变页面,其原理是改变的是内存 3.ajax实现 创建ajax引擎 为ajax对象绑定监听 绑定提交地址(get/...post) 发送请求 总结: 所有的异步访问都是通过ajax引擎 二、JSON传递数据(重点) 1.JSON在ajax中数据传递格式 JSON传递数据的一种格式,当使用异步传输的时候, 当服务器响应数据的时候...,需要使用一种格式在客户端和服务端进行传递 当服务端响应给客服端的时候响应的是字符串或者xml(ResponseText/ResponseXML), 如果响应一个对象给客户端的时候就不能表示. 2.JSON...格式 三、jQuery中的Ajax(重点) 再实际开发中使用下面三种方式: $.post(url,[date],[callback],[type]); $.get(url,[date
JQuery中bind和unbind函数 测试: 页面代码: <input type="checkbox...[type='button']").click(function(){ alert("aaaa"); }); } } alert("aaaa")会执行三次,在事件嵌套事件中,不希望看到这样的情况...能够移除所有的或被选的事件处理程序,或者当事件发生时终止指定函数的运行。...data 为可选参数,作文event.data属性值传递给事件对象的额外数据对象。 function 是用来绑定的处理函数。...(); 例2:删除p的click事件 $("p").unbind("click"); 例2:删除p元素click事件后出发的test函数 和 添加p元素click事件后触发的test函数 $("
),这几天在看.Net MVC4的时候,看到微软官方出的jquery.validate.unobtrusive.js,再看看其MVC4产生的客户端代码,我被震撼了,可读性变强了,编程的复杂度降低了,看来不能老守旧...如果我们做基于HTML5的开发,其实不用.NET MVC4,也可以直接用其jquery.validate.unobtrusive.js,这样我们的Html和客户端的验证工作就会变得很简单。.../docs.jquery.com/Plugins/Validation[/URL] 对于jquery.validate.unobtrusive.js,暂时没找到官方的帮助和网页: Unobtrusive.../ajax/mvc/3.0/jquery.validate.unobtrusive.jshttp://ajax.aspnetcdn.com/ajax/mvc/3.0/jquery.validate.unobtrusive.min.js.../3.0/MicrosoftMvcAjax.debug.js 附上微软官方的几个链接: [URL=http://msdn.microsoft.com/en-us/gg618485]ASP.NET
大家好,又见面了,我是你们的朋友全栈君。...vue项目中,需要把 moment.js 挂载到全局上(即vue的原型链上),访问时直接使用 this.moment() ; vue项目中不挂载到全局,单文件(单组件)使用: ==>...加/减 ==>> 操作之前必须使用 this.moment(日期变量) ;将要操作的日期转为 moment.js 可以处理的日期时间格式 加法:this.moment().add(1, ‘months...moment.js 自身的时间格式。...可以用 format 转换为自己想要的格式,也可以用 diff 方法做时间差的计算 10.
前言 之前总是不清楚原生JS和jQuery中有哪些循环遍历函数,而且有时候还总是把原生JS方法当成jQuery方法来用,以致于项目总是报错,并且还不知道是什么原因。...DOM对象和jQuery对象如何互相转换? 首先,先说一下DOM对象和jQuery对象如何转换?这样原生JS和jQuery的方法,我们就可以随意使用了。...原生JS循环遍历函数 1.for() for循环得知道数组的长度才能循环。它比较常用,这里就不多说了。 2.forEach () 不需要知道数组长度,也可以对数组中每一个元素进行操作。...every() 方法使用指定函数检测数组中的所有元素: 如果数组中检测到有一个元素不满足,则整个表达式返回 false ,且剩余的元素不会再进行检测。 如果所有元素都满足条件,则返回 true。...(arr1); //结果为:["z"] 4.inArray() 函数用于在数组中查找指定值,并返回它的索引值(如果没有找到,则返回-1) 提示:源数组不会受到影响,过滤结果只反映在返回的结果数组中。
JavaScript中的函数定义: //定义函数jiSun function jiSuan(){ alert("这是函数jiSuan"); } //调用函数...function是定义函数,并不会执行,调用函数时才会寻找该函数名的定义内容。 JavaScript中函数的定义和调用先后顺序可以先写调用在写定义。...补充:强类型语言中有默认值的函数,js不支持有默认值的函数 function jiSuan(a,b=2){ alert(a+b); } //调用函数 jiSuan...(3); JavaScript中的常用函数: document.write(""); 输出语句 Math.random();获取0-1之间的随机数 document.write(Math.random...如果查找成功,返回字符串中匹配的索引值。否则返回 -1 。
html lang="en"> Document //工厂函数是专门创建对象的函数
大家好,又见面了,我是你们的朋友全栈君。 匿名函数里的对象,跟定义匿名函数页面的上下文有关,而与调用匿名函数的页面无关。 很拗口。...showWorkSpace(callback, h) { var height = 500; callback("map_workspace",height); } //在该“容器”页面中的某个...frame frameMap' style='width:100%;height:" + h + ";' src='" + url + "'>"); }); 匿名函数在...iframe里定义,而在“容器”页面执行,而$(“#map_workspace”)对象很明显在“容器”页面上,但偏偏,没有获得我们预期的结果。...showWorkSpace(callback, h) { var height = 500; callback($("#map_workspace"),height); } //在该“容器”页面中的某个
map函数 首先让我们回顾一下,map函数的第一个参数callback: var new_array = arr.map(function callback(currentValue[, index[,...parseInt函数 parseInt 基数是一个介于2和36之间的整数。...parseInt(string, radix) //接收两个参数,第一个表示被处理的值(字符串),第二个表示为解析时的基数。 模拟情况 了解这两个函数后,我们可以模拟一下运行情况。...这个时候返回1 parseInt('2', 1) //基数为1(1进制)表示的数中,最大值小于2,所以无法解析,返回NaN parseInt('3', 2) //基数为2(2进制)表示的数中,最大值小于...3,所以无法解析,返回NaN map函数返回的是一个数组,所以最后结果为[1, NaN, NaN]
领取专属 10元无门槛券
手把手带您无忧上云