关于angular 双向绑定 一直调用接口的问题

如题

今天做导航栏的动态加载功能的时候,发现我调用查询是否显示的接口一直被重复调用好几次(起码5、6次),后面才恍然大悟,本身angularjs就是双向绑定动态加载的。近期可能刚收假一下没清醒。

  • 一般情况下写angularjs的方法是:
 $scope.myFun = function (){
var aa='todo';
console.log(111);
return false; 
});

前台调用ng-if或者ng-hide 动态获取这个方法返回的状态,处理显示或者隐藏 你会发现会一直打印 111 因为angularjs的双向绑定,动态加载的模式。会一直循环刷新这个值的状态的。
  • 如何只调用一次就不再执行了呢 使用 $timeout 并且不用scope去定义方法
var myFun = function() {
       $.get('api/getShow.mvc', function(response) {           
           $scope.hide = response.show;
       });
    }
    $timeout(function() {
        myFun();
    }, 1000);
  • 再记录一个请求接口时报415 参数类型不对的问题,检查调用的位置请求参数是字符串还是对象
此问题的原因是因为前后端数据交互出现json数据类型不符合

json 分为两种类型;
(1) json 对象类型,即前端定义的Content type 为 application/x-www-form-urlencoded等
(2) json字符串类型,即前端定义的Content type 为 application/json

解决办法

前端传输的json数据类型和后端使用的注解应有正确的对应关系
当前端请求传Json对象则后端使用@RequestParam注解;
当前端请求传Json对象的字符串则后端使用@RequestBody注解。

参考:https://blog.youkuaiyun.com/LoveTrainHY/article/details/122405744

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值