如题
今天做导航栏的动态加载功能的时候,发现我调用查询是否显示的接口一直被重复调用好几次(起码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