目录
同源:
跨域:
?跨域请求:?
?JSONP:
JQ中的JSONP:
防抖:
节流:
同源:
data:image/s3,"s3://crabby-images/dbd31/dbd3135c6f77f6d32b7d0aebacd3b0582cac0d33" alt=""
?data:image/s3,"s3://crabby-images/56f5c/56f5c120f53e99cd3fd4b80d75dede27c716e853" alt=""
跨域:
data:image/s3,"s3://crabby-images/e8827/e88274eb533267a97fbad7a50dc9b6c12d871734" alt=""
?data:image/s3,"s3://crabby-images/50f70/50f70b770f76395330ed346115ed5ab3035c4139" alt=""
?跨域请求:data:image/s3,"s3://crabby-images/dfad0/dfad0d59987b5eb1653c7608bb8a81add5bd7fda" alt=""
?JSONP:
data:image/s3,"s3://crabby-images/a0653/a0653150fe96b3dc9a0544192a56cc896dd81c90" alt=""
?跨域请求报错:data:image/s3,"s3://crabby-images/db413/db413a25ebb53ae685aba6d2880eaf47c1666e78" alt=""
?两个不同域的js:?data:image/s3,"s3://crabby-images/71e6a/71e6a43a4ae61441f2db0e4ffec11599edcc3b6d" alt=""
??data:image/s3,"s3://crabby-images/e97fb/e97fbf73e9423463b9328c05fccba49b7065871f" alt=""
JQ中的JSONP:
data:image/s3,"s3://crabby-images/5622d/5622d3b5e9e177ccb62a074ab17f9b69a94fdc9b" alt=""
data:image/s3,"s3://crabby-images/abe36/abe363afabf8570d72bd90b89b1e08a06d9501c3" alt=""
data:image/s3,"s3://crabby-images/07faf/07faf8fd584c7d2f01b27d5c6b53dcf7d083c577" alt=""
防抖:
data:image/s3,"s3://crabby-images/ca581/ca5814e27a6c216852f8e0175a70c23bdfc14e77" alt=""
?data:image/s3,"s3://crabby-images/07553/075534dbd30bc5f476689ea660d8704164f6bbab" alt=""
?防抖实际上就是一种利用settimeout来不断清除定时器和启动定时器的方法。
下面给出一个类似某宝搜索框的下拉内容实现代码:
<button class="btn-get-TBSearch">jsonp get taobao Search</button>
<input type="text" name="searchBar" id="searchBar" placeholder="搜索">
<div class="tpl-List"></div>
<script type="text/html" id="tpl-List">
<ul>
{{each data}}
<li>{{$value}}</li>
{{/each}}
</ul>
</script>
<script>
//jsonp请求淘宝搜索接口
function getSuggestList(userWrite) {
$.ajax({
url: 'http://suggest.taobao.com/sug?q=' + userWrite,
dataType: 'jsonp',
success: res => {
// console.log(res)
getList = res
}
})
}
//防抖
let PRMtimer=null
function preventReqMore(userWrite){
clearTimeout(PRMtimer)
PRMtimer=setTimeout(()=>{
getSuggestList(userWrite)
},2000)
}
let getList = []
let userTypeIn=''
$('#searchBar').on('input propertychange',function () {
userTypeIn=$(this).val()
$('.btn-get-TBSearch').click()
})
$('.btn-get-TBSearch').on('click', e => {
preventReqMore(userTypeIn)
// console.log(getList)
//这里我们的ajax完成方法作用于当前作用域中,不会影响其它ajax
$(document).ajaxComplete(function () {
if (getList !== []) {
// console.log(getList)
let newList=[]
$.each(getList,function (index,item) {
// console.log(item)
$.each(item,function (index1,item1) {
// console.log(item1)
$.each(item1,function (index2,item2) {
if (index2===0){
newList.push(item2)
}
})
})
})
// console.log(newList)
let templateData={
data:newList
}
let getHtml = template('tpl-List', templateData)
$('.tpl-List').html(getHtml)
} else {
console.log('null')
}
})
})
</script>
?其中用到了防抖,jsonp等思想,请耐心领会。
节流:
data:image/s3,"s3://crabby-images/81553/8155331051285d350ce36b5b6eed4fccf7cb4e35" alt=""
data:image/s3,"s3://crabby-images/7daff/7daffacc4a63b45e6a16a56a168152b86a035c57" alt=""
?data:image/s3,"s3://crabby-images/18042/180420d8e399a41be20af8056ea439d4b7399986" alt=""
?鼠标跟踪事件优化:
//节流阀
let MouseMoveTimer=null
$(document).on('mousemove',function (e) {
if (MouseMoveTimer===null){
MouseMoveTimer=setTimeout(function () {
$('.yellowPoint').css('top',e.pageY).css('left',e.pageX)
console.log(e.pageX,e.pageY)
MouseMoveTimer=null
},10)
}else return 0
})
?节流和防抖区别:data:image/s3,"s3://crabby-images/d9b23/d9b2330967f7a4c45d3c698d72344b12428a9d92" alt=""
?
|