task0002(三)- BOM + AJAX
BOM实现以下函数 判断是否为IE浏览器
// 判断是否为IE浏览器,返回-1或者版本号 function isIE() { var uUserAgent = navigator.userAgent; //保存浏览器的userAgent var ieAgent = uUserAgent.match(/msie (d+.d+)/i); if (ieAgent) { return ieAgent[1]; } else { if (uUserAgent.match(/Trident/7.0;/i)) { //处理到ie11. ieAgent = uUserAgent.match(/rv:(d+.d+)/i); return ieAgent[1]; } return -1; //不是ie浏览器。 } } Cookie相关秒味js的免费课程,把cookie讲的很好。 什么是cokie
设置cookie/** * 设置cookie * @param {String} cookieName 设置cookie名 * @param {String} cookieValue 对对应的cookie名 * @param {Number} expiredays 过期的时间(多少天后) */ function setCookie(cookieName,cookieValue,expiredays) { var oDate = new Date(); oDate.setDate(oDate.getDate() + expiredays); document.cookie = cookieName + "=" + cookieValue + ";expires=" + oDate; } 获取cookie值/** * 获取cookie * @param {String} cookieName 待寻找的cookie名 * @returns {String} 返回寻找到的cookie值,无时为空 */ function getCookie(cookieName) { var arr = document.cookie.split("; "); for (var i = 0; i < arr.length; i++) { var arr2 = arr[i].split("="); if (arr2[0] == cookieName) { return arr2[1]; } } return ""; } 删除cookies/** * 删除cookie * @param {String} cookieName 待删除的cookie名 */ function removeCookie(cookieName) { setCookie(cookieName,"1",-1) } 扩展阅读:sessionStorage、localStorage 和 cookie 之间的区别
Ajax任务描述学习Ajax,并尝试自己封装一个Ajax方法。实现如下方法: // function ajax(url,options) { // your implement } // 使用示例: ajax( 'http://localhost:8080/server/ajaxtest',{ data: { name: 'simon',password: '123456' },onsuccess: function (responseText,xhr) { console.log(responseText); } } ); options是一个对象,里面可以包括的参数为:
实现如下:
/** * AJAX函数封装 * @param {string} url 请求地址(必须) * @param {object} options 发送请求的选项参数 * @config {string} [options.type] 请求发送的类型。默认为GET。 * @config {Object} [options.data] 需要发送的数据。 * @config {Function} [options.onsuccess] 请求成功时触发,function(oAjax.responseText,oAjax)。(必须) * @config {Function} [options.onfail] 请求失败时触发,function(oAjax)。(oAJax为XMLHttpRequest对象) * *@returns {XMLHttpRequest} 发送请求的XMLHttpRequest对象 */ function ajax(url,options) { //1.创建ajax对象 var oAjax = null; /** * 此处必须需要使用window.的方式,表示为window对象的一个属性.不存在时值为undefined,进入else * 若直接使用XMLHttpRequest,在不支持的情况下会报错 **/ if (window.XMLHttpRequest) { //IE6以上 oAjax = new XMLHttpRequest(); } else { oAjax = new ActiveXObject("Microsoft.XMLHTTP"); } //2.连接服务器 //open(方法,url,是否异步) var param = ""; //请求参数。 //只有data存在,且为对象使才执行 var data = options.data ? options.data : -1; //缓存data if (typeof (data) === "object") { for (var key in data) { //请求参数拼接 if (data.hasOwnProperty(key)) { param += key + "=" + data[key] + "&"; } } param.replace(/&$/,""); } else { param = "timestamp=" + new Date().getTime(); } //3.发送请求 var type = options.type ? options.type.toUpperCase() : "GET"; if (type === "GET") { oAjax.open("GET",url + "?" + param,true); oAjax.send(); } else { oAjax.open("POST",true); oAjax.setRequestHeader("Content-type","application/x-www-form-urlencoded"); oAjax.send(param); } //4.接收返回 //OnRedayStateChange事件 oAjax.onreadystatechange = function () { if (oAjax.readyState === 4) { if (oAjax.status === 200) { //请求成功。形参为获取到的字符串形式的响应数据 options.onsuccess(oAjax.responseText,oAjax); } else { //先判断是否存在请求失败函数 //存在时,形参为XMLHttpRequest对象,便于进行错误进行处理 if (options.onfail) { options.onfail(oAjax); } } } }; return oAjax;//发送请求的XMLHttpRequest对象 } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |