知识大全 网站如何做到完全不需要jQuery也可以满足简单需求

Posted 元素

篇首语:无论你有多少知识,假如不用便是一无所知。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 网站如何做到完全不需要jQuery也可以满足简单需求相关的知识,希望对你有一定的参考价值。

网站如何做到完全不需要jQuery也可以满足简单需求  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  据统计 目前全世界 %的网站使用它 也就是说 个网站里面 有 个使用jQuery 如果只考察使用工具库的网站 这个比例就会上升到惊人的 %

  

  虽然jQuery如此受欢迎 但是它臃肿的体积也让人头痛不已 jQuery 的原始大小为 KB 优化后为 KB 如果是支持IE 的jQuery 原始大小为 KB 优化后为 KB

  这样的体积 即使是宽带环境 完全加载也需要 秒或更长 更不要说移动设备了 这意味着 如果你使用了jQuery 用户至少延迟 秒 才能看到网 页效果 考虑到本质上 jQuery只是一个操作DOM的工具 我们不仅要问 如果只是为了几个网页特效 是否有必要动用这么大的库?

  

   年 jQuery诞生的时候 主要用于消除不同浏览器的差异(主要是IE ) 为开发者提供一个简洁的统一接口 相比当时 如今的情况已经发生了很大的变化 IE的市场份额不断下降 以ECMAScript为基础的JavaScript标准语法 正得到越来越广泛的支持 开发者直接使用JavScript标准语法 就能同时在各大浏览器运行 不再需要通过jQuery获取兼容性

  下面就探讨如何用JavaScript标准语法 取代jQuery的一些主要功能 做到jQuery free

  

  一 选取DOM元素

  jQuery的核心是通过各种选择器 选中DOM元素 可以用querySelectorAll方法模拟这个功能

  var $ = document querySelectorAll bind(document);

  这里需要注意的是 querySelectorAll方法返回的是NodeList对象 它很像数组(有数字索引和length属性) 但不是数组 不能使用pop push等数组特有方法 如果有需要 可以考虑将Nodelist对象转为数组

  myList = Array prototype slice call(myNodeList);

  二 DOM操作

  DOM本身就具有很丰富的操作方法 可以取代jQuery提供的操作方法

  尾部追加DOM元素

  // jQuery写法 $(parent) append($(child));

  // DOM写法 parent appendChild(child)

  头部插入DOM元素

  // jQuery写法 $(parent) prepend($(child));

  // DOM写法 parent insertBefore(child parent childNodes[ ])

  删除DOM元素

  // jQuery写法 $(child) remove()

  // DOM写法 child parentNode removeChild(child)

  三 事件的监听

  jQuery的on方法 完全可以用addEventListener模拟

  Element prototype on = Element prototype addEventListener;

  为了使用方便 可以在NodeList对象上也部署这个方法

  NodeList prototype on = function (event fn) [][ forEach ] call(this function (el) el on(event fn); ); return this; ;

  四 事件的触发

  jQuery的trigger方法则需要单独部署 相对复杂一些

  Element prototype trigger = function (type data) var event = document createEvent( HTMLEvents ); event initEvent(type true true); event data = data || ; event eventName = type; event target = this; this dispatchEvent(event); return this; ;

  在NodeList对象上也部署这个方法

  NodeList prototype trigger = function (event) [][ forEach ] call(this function (el) el[ trigger ](event); ); return this; ;

  五 document ready

  目前的最佳实践 是将JavaScript脚本文件都放在页面底部加载 这样的话 其实document ready方法(jQuery简写为$(function))已经不必要了 因为等到运行的时候 DOM对象已经生成了

  六 attr方法

  jQuery使用attr方法 读写网页元素的属性

  $("#picture") attr("src" "//url/to/image");

  DOM元素允许直接读取属性值 写法要简洁许多

  $("#picture") src = "//url/to/image";

  需要注意 input元素的this value返回的是输入框中的值 链接元素的this href返回的是绝对URL 如果需要用到这两个网页 元素的属性准确值 可以用this getAttribute( value )和this getAttibute( href )

  七 addClass方法

  jQuery的addClass方法 用于为DOM元素添加一个class

  $( body ) addClass( hasJS );

  DOM元素本身有一个可读写的className属性 可以用来操作class

  document body className = hasJS ;

  // or

  document body className += hasJS ;

  HTML 还提供一个classList对象 功能更强大(IE 不支持)

  document body classList add( hasJS );

  document body classList remove( hasJS );

  document body classList toggle( hasJS );

  document body classList contains( hasJS );

  八 CSS

  jQuery的css方法 用来设置网页元素的样式

  $(node) css( "color" "red" );

  DOM元素有一个style属性 可以直接操作

  element style color = "red";;

  // or

  element style cssText += color:red ;

  九 数据储存

  jQuery对象可以储存数据

  $("body") data("foo" );

  HTML 有一个dataset对象 也有类似的功能(IE 不支持) 不过只能保存字符串

  element dataset user = JSON stringify(user);

  element dataset score = score;

  十 Ajax

  jQuery的Ajax方法 用于异步操作

  $ ajax( type: "POST" url: "some php" data: name: "John" location: "Boston" ) done(function( msg ) alert( "Data Saved: " + msg ); );

  我们可以定义一个request函数 模拟Ajax方法

  function request(type url opts callback)

  var xhr = new XMLHttpRequest();

  if (typeof opts === function ) callback = opts; opts = null;

  xhr open(type url);

  var fd = new FormData();

  if (type === POST && opts) for (var key in opts) fd append(key JSON stringify(opts[key]));

  xhr onload = function () callback(JSON parse(xhr response)); ;

  xhr send(opts ? fd : null);

  

  然后 基于request函数 模拟jQuery的get和post方法

  var get = request bind(this GET );

  var post = request bind(this POST );

  十一 动画

  jQuery的animate方法 用于生成动画效果

  $foo animate( slow x: += px )

  jQuery的动画效果 很大部分基于DOM 但是目前 CSS 的动画远比DOM强大 所以可以把动画效果写进CSS 然后通过操作DOM元素的class 来展示动画

  foo classList add( animate )

  如果需要对动画使用回调函数 CSS 也定义了相应的事件

  el addEventListener("webkitTransitionEnd" transitionEnded);

  el addEventListener("transitionend" transitionEnded);

  十二 替代方案

  由于jQuery体积过大 替代方案层出不穷

  其中 最有名的是zepto js 它的设计目标是以最小的体积 做到最大兼容jQuery的API zepto js 版的原始大小是 KB 优化后是 KB gzip压缩后为 KB

  如果不求最大兼容 只希望模拟jQuery的基本功能 那么 min js优化后只有 字节 而dolla优化后是 KB

  此外 jQuery本身采用模块设计 可以只选择使用自己需要的模块 具体做法参见它的github网站 或者使用专用的Web界面

  十三 参考链接

   Remy Sharp I know jQuery Now what? Hemanth HM Power of Vanilla JS Burke Holland Things You Should Stop Doing With jQuery

cha138/Article/program/Java/JSP/201311/20562

相关参考

知识大全 jquery图片放大功能简单实现

图片放大在某些例如商品细节放大图比较常见本文写了一个图片放大的示例适合日常应付有需求的朋友可以参考下 复制代码代码如下:cha138/Article/program/Java/JS

知识大全 我是学生 请问怎么可以自己的面板变白而且嫩滑 ? 不需要花很多钱 平时很简单就可以做到的方法 ?

我是学生请问怎么可以自己的面板变白而且嫩滑?不需要花很多钱平时很简单就可以做到的方法?美白面膜一、牛奶是最好的美白面膜,将3匙牛奶和3匙面粉搅匀,调制成糊状,涂满脸部,待面膜干后,再以温水按照洗脸步骤

知识大全 jquery 滚动条事件简单实例

这篇文章介绍了jquery滚动条事件的简单实例有需要的朋友可以参考一下 复制代码代码如下:cha138/Article/program/Java/JSP/201311/20441

家装设计有几点必须要做到?

家装设计有几点必须要做到?1、研究人的需要设计的根本宗旨就是以人为本而不是以物为本,室内设计在满足建筑的功能需要同时要更多的满足人的心理需求和活动规律。如业主惯用左手,那么在电器开关的设计上就应该注意

知识大全 jquery之超简单的div显示和隐藏特效demo

本篇文章是对jquery中的div显示和隐藏特效demo进行了详细的分析介绍需要的朋友可以参考下 复制代码代码如下:cha138/Article/program/Java/JSP/

知识大全 谢谢

我要仿一个网站,那个网站非常符合我的需要。不知道用什么办法才能简单的搬到!谢谢!网上有这样的网页资源分析器,可以把一个网站上面的所有资源全部下载回来。我要注册免费域名网站,要简单的,那个网站好?免费域

知识大全 使用jquery实现简单的ajax

本篇文章是对用jquery实现简单的ajax的实现方法进行了详细的分析介绍需要的朋友参考下   >页复制代码代码如下:<!DOCTYPEPUBLIC"//WC//DTDXHTML

知识大全 jquery异步跨域访问代码

下面是关于jquery异步跨域访问的简单实例需要的朋友可以参考一下 复制代码代码如下:cha138/Article/program/Java/JSP/201311/20034

知识大全 jquery简单的拖动效果实现原理及示例

本文为大家详细介绍下jQuery拖曵的简单实例具体的实现思路及代码如下感兴趣的朋友可以参考下哈希望对大家有所帮助 复制代码代码如下:cha138/Article/program/J

知识大全 简单实用jquery版三级联动select示例

本文主要为大家介绍下通过jquery实现三级联动select这里用到的json文件只是事例根据情况添加或编写感兴趣的朋友可以参考下哈希望对大家有所帮助   和js部分复制代码代码如下:<