参考文献:

https://www.cnblogs.com/lenghan/p/5777588.html

  根据原理解读,发现同一个页面如果多个ajax请求调用的jsonpCallback名字相同的话,会在执行完第一个jsonpCallback后,就会置为undefined

function setCoupons22222222222(){
    $.ajax({
        type: 'GET',
        url: "https://api.pangku.com/v1/coupons/channel?count=1&serialId=2824&brandId=2&regionId=1&ad_num=03",
        dataType:'jsonp',
        cache: true,
        jsonpCallback: 'setCouponsChannel',
        success:function(resultData){
        console.log("哈哈");
            console.log(resultData);
        },
        error:function(data){
            console.log(1234);
        }
    });
}
setCoupons22222222222();
setCoupons22222222222();

  暂时发现有两种解决方法:

第一种,设置不同的jsonpCallback名称,比如在for循环里调用的时候,每个名字加上循环的i来区分(实际上缓存就失效了?)

function setCoupons22222222222(i){
    $.ajax({
        type: 'GET',
        url: "https://api.pangku.com/v1/coupons/channel?count=1&serialId=2824&brandId=2&regionId=1&ad_num=03",
        dataType:'jsonp',
        cache: true,
        jsonpCallback: 'couponsChannel'+i,
        success:function(resultData){
        console.log("哈哈");
            console.log(resultData);
        },
        error:function(data){
            console.log(1234);
        }
    });
}

setCoupons22222222222(1);
setCoupons22222222222(2);
setCoupons22222222222(3);
setCoupons22222222222(4);
setCoupons22222222222(5);
setCoupons22222222222(6);

优化一下,让网站缓存继续可用:

var a=1;

function setCoupons22222222222(){
    a=a+1
    $.ajax({
        type: 'GET',
        url: "https://api.pangku.com/v1/coupons/channel?count=1&serialId=2824&brandId=2&regionId=1&ad_num=03",
        dataType:'jsonp',
        cache: true,
        jsonpCallback: 'couponsChannel'+a,
        success:function(resultData){
       console.log("哈哈");
            console.log(resultData);
        },
        error:function(data){
            console.log(1234);
        }
    });
}

setCoupons22222222222();
setCoupons22222222222();
setCoupons22222222222();
setCoupons22222222222();
setCoupons22222222222();
setCoupons22222222222();

第二种,定义jsonpCallback函数,但是不做处理,例如:

function setCoupons22222222222(){
    $.ajax({
        type: 'GET',
        url: "https://api.pangku.com/v1/coupons/channel?count=1&serialId=2824&brandId=2&regionId=1&ad_num=03",
        dataType:'jsonp',
        cache: true,
        jsonpCallback: 'setCouponsChannel',
        success:function(resultData){
        console.log("哈哈");
            console.log(resultData);
        },
        error:function(data){
            console.log(1234);
        }
    });
}
function setCouponsChannel(data){console.log("hello")};
setCoupons22222222222();
setCoupons22222222222();

你会发现先打印hello再打印上面的哈哈,就是说ajax返回后先调用jsonpCallback处理返回的数据,再将返回的数据传给success进行处理

----------------------------------------------------我是分割线--------------------------------------------------------------

另外一种情况是,在你发现ajax的时候,别人把你ajax注册到window对象的jsonpCallback函数置为undefined了

例如:

function setCoupons22222222222(){
    $.ajax({
        type: 'GET',
        url: "https://api.pangku.com/v1/coupons/channel?count=1&serialId=2824&brandId=2&regionId=1&ad_num=03",
        dataType:'jsonp',
        cache: true,
        jsonpCallback: 'setCouponsChannel',
        success:function(resultData){
            console.log(resultData);
        },
        error:function(data){
            console.log(1234);
        }
    });
       window.setCouponsChannel=null;
}
setCoupons22222222222();

jsonpCallback: xx is not a function的更多相关文章

  1. 关于IONIC 报错 XX is not a function

    刚开始 做一个项目,总是报错"XX is not  a function"   最后发现 原因 ,   原来是 服务的 注入位置 有问题. angular.module(" ...

  2. 学习angularjs时遇到 XX is not a function

        第一次练习就直接没效果:   "后不能直接以 function XXXcontroller (){ code......}这样的方式直接注册监听器了. 以后必须angular.mod ...

  3. jquery插件一直报错:xx is not a function

    当然像js文件未引用或者js插件使用方法不对这样的解决办法想必大家都已经试过了. 那么在放弃前请最后看一下是不是引用了两个jquery文件. 引用了两个jquery文件! 引用了两个jquery文件! ...

  4. var 与function的权重浅析

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. 15分XX秒后订单自动关闭(倒计时)

    //订单记录 function get_order(){ //请求订单ajax方法 XX.send_api("method",{data},function(){ var date ...

  6. 跨域名设置cookie或获取cookie

    可以使用jquery里面的ajax中的jsonp的方式来访问就可以了.代码如下: $.ajax({ url: 'your url', data: {'xx' : 'xx', 'xx2' : 'xx2' ...

  7. iOS之UIWebView无法获取web标题

    最近遇到了一个问题,就是在UIWebView的代理方法里,执行document.title的js代码无法获取网页标题,代码如下: - (void)webViewDidFinishLoad:(UIWeb ...

  8. :jQuery实例【DEMO】

    前言: 今天2月最后一天,写一篇jQuery的几个实例,算是之前前端知识的应用.写完这篇博客会做一个登陆界面+后台管理(i try...) 一.菜单实例 最开始的界面: 点击菜单三后的界面:   二. ...

  9. 前端跨域实现的几种方式?及使用Nginx反向代理配置。

    早期为了防止CSRF(跨域请求伪造)的攻击,浏览器引入了同源策略(SOP)来提高安全性.而所谓"同源策略",即同域名(domain或ip).同端口.同协议的才能互相获取资源,而不能 ...

随机推荐

  1. FreeNas搭建踩坑指南(一)

    0x00 背景 最近公司的旧群晖服务器Raid6,因为同时坏了两块硬盘存储池损毁,所以领导决定买了Dell R730自己搭NAS,选来选去最后选了FreeNAS,这里记录一些踩过的坑. 0x01 问题 ...

  2. 亿级流量场景下,大型架构设计实现【全文检索高级搜索---ElasticSearch篇】-- 中

    1.Elasticsearch的基础分布式架构: 1.Elasticsearch对复杂分布式机制的透明隐藏特性2.Elasticsearch的垂直扩容与水平扩容3.增减或减少节点时的数据rebalan ...

  3. SpringBoot+MyBatis配置多数据源

    SpringBoot 可以支持多数据源,这是一个非常值得学习的功能,但是从现在主流的微服务的架构模式中,每个应用都具有唯一且准确的功能,多数据源的需求很难用到,考虑到实际情况远远比理论复杂的多,这里还 ...

  4. C++ 子类继承父类纯虚函数、虚函数和普通函数的区别

    C++三大特性:封装.继承.多态,今天给大家好好说说继承的奥妙 1.虚函数: C++的虚函数主要作用是“运行时多态”,父类中提供虚函数的实现,为子类提供默认的函数实现.子类可以重写父类的虚函数实现子类 ...

  5. Linux(CentOS 7)安装测试mysql5.6服务

    1.rpm -qa | grep mysql,查看原系统中是否有已经安装得mysql. 注:centos7系统在安装完成后,未安装mysql任何版本. 2. rpm -e --nodeps mysql ...

  6. C#零基础入门-2-Visual Studio (VS)程序初始化及各组成部分

    X:\Program Files (x86)\Microsoft Visual Studio 14.0\Common7\IDE\devenv.exe 可以使用桌面快捷方式启动,也可以从开始菜单启动,还 ...

  7. [20190416]完善shared latch测试脚本2.txt

    [20190416]完善shared latch测试脚本2.txt --//昨天测试shared latch,链接:http://blog.itpub.net/267265/viewspace-264 ...

  8. 配置用户Log on as service

    Logon to the computer with administrative privileges. Open the ‘Administrative Tools’ and open the ‘ ...

  9. Andriod studio 打包aar

    因为项目不同,有些公用库而且还是c++的,还有一些带资源的,简单的复制遇到库升级又是一轮配置,编译成aar则解决这些麻烦. 但是默认andriod studio的make moudle只生成debug ...

  10. kvm虚拟化

    1.kvm虚拟化介绍 什么是虚拟化 虚拟化就是通过模拟计算机硬件(cpu,内存,硬盘,网卡)来实现在一台物理服务器上运行同时多个不同的操作系统,并且使每个操作系统之间都是互相隔离的 为什么要学习虚拟化 ...