XML |
XML文档可使用常用的attr()/find()/filter()等处理
function (data, textStatus) {
var username = $(data).find('comment').attr('username');
var content = $(data).find('comment content').text();
var txtHtml = '<div class=\'comment\'><h6>' + username + ':</h6><p class=\'para\'>' + content + '</p></div>';
$('#resText').html(txtHtml); // 把返回的数据添加到页面上
}
</td> </tr>
<tr>
<td>json</td>
<td>json格式简洁,易读,对返回处理后输出html
function (data, textStatus) {
var username = data.username;
var content = data.content;
var txtHtml = '<div class=\'comment\'><h6>' + username + ':</h6><p class=\'para\'>' + content + '</p></div>';
$('#resText').html(txtHtml); // 把返回的数据添加到页面上
},
'json'); //要求服务器返回json格式
</td> </tr>
</tbody> </table>
好处与利弊:html片段最简单;json数据重用、性能、大小、较好; xml远程应用程序未知时较好,适用于任何语言;
$.getScript('test.js') 当然,也有回调:$.getScript('test.js',function(){
$('#go').click(function(){
.....
})
})
$.getJSON('test.json') 当然,也有回调:$.getJSON('test.json',function(data){
//data返回数据
})
})
通过$.getJSON得到的数据data,可使用$.each()来遍历[对象和数组]$.each(data, function (i, elem) {
console.log(i); //i表示索引,elem表示值
console.log(elem['username']);
})
通过JSONP加载其它网站数据;跨域首选
$.getJSON('http://api...../',function(data){
$.each(data[obj],function(i,elem){
.....
//i可作为判断条件,退出each循环,return false;
})
})
底层$.ajax(options)方法 <style> .ajax-tb-1 { border-collapse: collapse }
.ajax-tb-2{border-collapse: collapse}
.ajax-tb-2 td{border:1px solid #ddd;padding:5px 10px;line-height: 2;}
.ajax-tb-2 tr>td:nth-of-type(2){white-space: nowrap; }
.ajax-tb-1 td, .ajax-tb-1 th { border: 1px solid #ddd; padding: 5px 10px; line-height: 2; }
</style>
該方法只有一個參數,所有包含在$.ajav()裏,參數以key/value形式,所有參數除url外都是可選
參數名 |
類型 |
說明 |
url |
string |
默認,發送,請求地址 |
type |
string |
post/get,默認get,注意put/delete部分瀏覽器不支持 |
data |
obj or string |
發送到服務器的數據,如非字符串,則自動轉字符串形式 <br/>請求獎附加在url後,防止自動轉可查看processData選項,對象必須為key/value格式;<br/>例如
{fool:'bar1',foo2:'bar2'} ==>>&foo1=bar1&foo2=bar2
<br/>如果是數組,轉為不同值對應同一個名稱。
{foo:['bar1','bar2']}==>>&foo=bar1&foo=bar2
|
dataType |
string |
預期服務器返回類型,不指定:自動按http包mime信息返回responseXML或responseText,並作為callback參數傳遞;可用類型:<br/>xml:返xml文檔,可用jq處理 <br/>html:純html信息,包含的script標籤會在插入dom時執行<br/>script:純js代碼,不自動緩存結果,除非設置cache,注意:遠程請求時所有跨域請求都轉為get請求
<br/>json:返回JSON數據;<br/>jsonp:使用JSONP形式調用函數時,如:myurl?callback=?,jq將自動替換後一個?為正確函數名 <br/>text:純txt字符串
|
beforeSend |
Function |
發送前可修改XMLHttpRequst對象函數,如:添加算定義HTTP頭,在beforeSend中返回false可取消本次ajax請求,XMLHttpRequest對象是惟一請求;<br/>
function(XMLHttpRequest){
this //調用本次ajax請求傳傳遞的options參數
}
|
complete |
Function |
請求完成後回調,成功失敗都可調用;<br/>參數:XMLHttpRequest對像和一個描述成功請求類型的string,
function(XMLHttpRequest,textStatus){
this //調用本次ajax請求傳傳遞的options參數
}
|
success |
Function |
請求成功後callback <br/> 1).由服務器返回,按給的dataType參數進行處理後數據 ; <br/>2).描述狀態string; <br/>
function(data,textStatus){
data; //可能是xmlDoc,jsonObj,html,text等等,
this; //調用本次ajax請求傳傳遞的options參數
}
|
error |
Function |
請求失敗時調用,3參數:
function(XMLHttpRequest ,textStatus,errorThrown){
//通常情況下textStatus和errorThown只有其中一個包含信息
this //調用本次ajax請求傳傳遞的options參數
}
|
global |
Boolean |
默認true,表示是否觸發全局ajax事件,設置false將不觸發,AjaxStart或AjaxStop可用於控制各種Ajax事件; |
代替$.getScript() $(function () {
$('send').click(function () {
$.ajax({
type:'GET',
url:'test.js',
dataType:'script'
})
})
})
代替$.getJSON() $.ajax({
type:'GET',
url:'test.json',
dataType:'json',
success: function (data) {
var html=''
$.each(data, function (index,elems) {
html +=index
+':'
+elems['username']
+':'
+elems['content']
})
$('body').html(html)
}
})
test.json [
{
"username": "张三",
"content": "沙发."
},
{
"username": "李四",
"content": "板凳."
},
{
"username": "王五",
"content": "地板."
}
]
1、serialize()方法,表單序列化,所有元素必須設置name,使用name來獲取;<form action="" id="f2">
<p>user:<input type="text" name="user" id=""/></p>
<p>password:<input type="password" name="pws" id=""/></p>
<input type="checkbox" name="ck" id=""/>
<input type="checkbox" name="ck2" id=""/>
<input type="radio" name="rrr" id=""/>
<input type="radio" name="rrr" id=""/>
<input type="radio" name="rrr" id=""/>
<p><input type="button" id="send2" value="提交"/></p>
</form>
$('#send2').click(function () {
console.log($('#f2').serialize());
console.log($('#f2').serializeArray()); //若使用serializeArray()輸出對像如下圖
})
輸出:user=elmok&pws=elmokpws&ck2=on&rrr=on 輸出對象: 所以可使用$.each() var fdata = $('#f2').serializeArray(),
$.each(fdata ,function(i,elems){
$('body').append(fdata.value + '')
})
例子: <form id="form1" action="#">
<p>评论:</p>
<p>姓名: <input type="text" name="username" id="username" /></p>
<p>内容: <textarea name="content" id="content" rows="2" cols="20"></textarea></p>
<p><input type="button" id="send" value="提交"/></p>
</form>
<div id="resText"></div>
為取得姓名和內容,必須將字段一個個添加到data參數中 $('#send').click(function () {
$.get('get1.php',{
username:$('#username').val(),
content:$('#content').val()
}, function (data, textStatus) {
$('#resText').html(data) //返回頁面
})
})
少量可以,多則使用serialize()方法 $('#send').click(function () {
$.get('get1.php',$('#form1').serialize(), function (data, textStatus) {
$('#resText').html(data)
})
})
需要注意:$.get()方法中,data參數不僅可使用映射方式: {
username:$('#username').val(),
content:$('#content').val()
}
也可使用字符串[中文問題]方式:注意,字符串無{}號 $('#send').click(function () {
$.get('get1.php',
"username="+encodeURIComponent($('#username').val())+"&content="+encodeURIComponent($('#content').val())
, function (data, textStatus) {
$('#resText').html(data)
})
})
3、$.param()方法 serialize()方法核心,對一個arr或obj按照key/value進行序列化var obj = {a:1,b:2,c:3}
var k = $.param(obj)
//輸出:a=1&b=2&c=3
jq中的ajax全局事件 加載中loading....提示,定義好loading...... $("#loading").ajaxStart(function(){
$(this).show();
});
$("#loading").ajaxStop(function(){
$(this).hide();
});
其他地方使用,仍有效,因為是全局;
另外幾個方法 ajaxComplete(fn..):請求完成時執行;
ajaxError(fn..):發生錯誤時執行,捕捉到錯誤可作為最後一個參數傳遞;
ajaxSend(fn..):請求發送前執行;
ajaxSuccess(fn...):請求成功時執行;
1、jq1.5之前,如不想某個ajax請求受全局方法影響 $.ajax({
url:'...',
global:false
})
1、jq1.5之後,如不想某個ajax請求受全局方法影響,則在每次發送請求之前設置 $.ajaxPrefilter(function (options) {
options.global = true;
})
October 14, 2013
運動公式:
弹性:速度+=(目标点-当前值)/系数 必須是全局变量 速度*=摩擦系数[小于1] 缓冲: var 速度 = (目标点-当前值)/系数 局部變量
速度取整
系數取值: 系数: 6,7,8 摩擦系数:0.75
運動的基本步驟: 1、清除定時器; 2、開定定時器:寫條件... 寫彈性運動步驟: 1)、写两个速度公式; 2)、写两个停止条件:速度的绝对值<=1,距离[目標點-本身位置]的绝对值<=1; 3)、修正偏差:距離 == 目標點;速度 ==0 function sMove() {
clearInterval(_t)
_t = setInterval(function () {
//1、写两个速度公式
_speed+=(500-div.offsetLeft)/6
_speed*=0.75
//2、写两个停止条件 速度的绝对值,距离的绝对值
if(Math.abs(_speed)<=1 && Math.abs(500-div.offsetLeft)<=1){
clearInterval(_t)
//3/修正偏差
div.style.left = '500px'
_speed = 0;
}
else{
div.style.left = div.offsetLeft+_speed+'px'
}
}, 30)
}
首先,滾動歌詞的效果 1、定認兩個div,定位重疊 <div id="div1"><span>红眼睛幽幽的看着这孤城,如同苦笑挤出的高兴,浮华盛世做分手布景</span></div>
<div id="div2"><span>红眼睛幽幽的看着这孤城,如同苦笑挤出的高兴,浮华盛世做分手布景</span></div>
2、第一個div1定住不動;div2外層限制寬高加overflow:hidden; div2內層span設置定位,限制高,寬2000px; #div2{color:#cd0000;height:36px;width:36px;overflow:hidden;}
#div2 span{position:absolute;left:0;top:0;width:2000px;height:20px}
3、理解,div2外層向左移動+1px/每次時,內層span2同時相反移動 setInterval(function(){
div2.style.left = div2.offsetLeft+1+'px';
span2.style.left = -div2.offsetLeft+'px';
},30)
so,彈性菜單的例子是: 1、佈局:mark為需要在上面運動的項; <ul id="ul1">
<li id="mark">
<ul>
<li>首页</li>
<li>论坛</li>
<li>视频</li>
<li>留言</li>
</ul>
</li>
<li class="box">首页</li>
<li class="box">论坛</li>
<li class="box">视频</li>
<li class="box">留言</li>
</ul>
See the Pen gaGVEL by elmok (@elmok) on CodePen. <script async src="//assets.codepen.io/assets/embed/ei.js"></script>
当attr = width || height 時,低IE會出現彈性過過界,不允許負值,即出現錯誤; 所以
var H = div.offsetHeight + _speed;
if(H<0){ //ie下元素的高度不能为负值;
H=0;
}
弹性运动整合版 function sMove(obj, json, fn) {
clearInterval(obj.timer);
var json2 = copy(json);
obj.timer = setInterval(function () {
var bStop = true;
for (var attr in json) {
var iCur = 0;
if (attr == 'opacity') {
iCur = Math.round(parseFloat(getStyle(obj, attr)) * 100);
} else {
iCur = parseInt(getStyle(obj, attr));
}
json2[attr] += (json[attr] - iCur) / 6;
json2[attr] *= 0.75;
if (Math.abs(json2[attr]) < 1 && Math.abs(json[attr] - iCur) <= 1) {
if (attr == 'opacity')
{
obj.style.filter = 'alpha(opacity:' + (json[attr]) + ')';
obj.style.opacity = (json[attr]) / 100;
}
else
{
obj.style[attr] = json[attr] + 'px';
}
} else {
bStop = false;
if (attr == 'opacity')
{
obj.style.filter = 'alpha(opacity:' + (iCur + json2[attr]) + ')';
obj.style.opacity = (iCur + json2[attr]) / 100;
}
else
{
obj.style[attr] = Math.round(iCur + json2[attr]) + 'px';
}
}
}
if (bStop) {
clearInterval(obj.timer);
fn && fn.call(obj)
}
}, 30);
};
function getStyle(obj, attr) {
if (obj.currentStyle) {
return obj.currentStyle[attr];
} else {
return getComputedStyle(obj, false) [attr];
}
}
function copy(obj) {
var o = {
};
for (var i in obj) {
o[i] = 0;
}
return o;
}
碰撞运动,找到临界点,再确定运动方向,改对应的速度 ,將速度取反; var _div = document.getElementById('div1')
var _speedX = 10;
var _speedY = 10;
sMove()
//碰撞运动,1、找到临界点,再确定运动方向,改对应的速度 (速度取反)
function sMove(){
setInterval(function () {
var L = _div.offsetLeft +_speedX;
var T = _div.offsetTop +_speedY;
if(T>document.documentElement.clientHeight-_div.offsetHeight){
T =document.documentElement.clientHeight-_div.offsetHeight
_speedY *=-1
}
if(T<0){
T=0;
_speedY*=-1 //又变为正
}
if(L>document.documentElement.clientWidth-_div.offsetWidth){
L =document.documentElement.clientWidth-_div.offsetWidth
_speedX *=-1
}
if(L<0){
L=0;
_speedX*=-1 //又变为正
}
_div.style.left = L +'px'
_div.style.top = T +'px'
},30)
}
自由落體運動、拋物線運動 自由落體: 只需改變top值,接觸到目標點後速度取反向上運動,再使用摩擦系數使速度停下來;
拋物線: 添加left方向速度及判定,摩擦系數使速度停下來,注意初始化目標位置及初始化速度;
See the Pen ojodqO by elmok (@elmok) on CodePen. <script async src="//assets.codepen.io/assets/embed/ei.js"></script>
iphone拖動效果 首先,拖動obj.onmousedown = function(e){
var e = e || event;
....
document.onmousemove = function(e){
...
}
document.onmouseup = function(e){
document.onmousemove = document.onmouseup = null;
...
}
return false;
}
mousemove,鼠標移動的距離 == 元素left值移動的距離 ul1.style.left = e.clientX-disX + 'px' mouseup時,元素需要移動的距離為一個li的距離,產生的效果由彈性公式生成; 當mousedown時存鼠標位置downX,與抬起時位置對比,小於走左,大於走右; 使用變量inow++ --
See the Pen KdyRrX by elmok (@elmok) on CodePen. <script async src="//assets.codepen.io/assets/embed/ei.js"></script>
公告碰撞效果
See the Pen meqLgV by elmok (@elmok) on CodePen. <script async src="//assets.codepen.io/assets/embed/ei.js"></script>
- « Previous
- 1
- ...
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- ...
- 54
- Next »
|