angular.js - angular的指令如何赋值给控制的值呢?

浏览:49日期:2023-01-05

问题描述

比如,我在主控制器中有一个参数是: $scope.datas

然后,我在这里有一个指令,在指控的控制器上请求数据,然后想要赋值给主控制器的 $scope.datas。如何得逞呢?

如,指令:

app.directive(’profitSearch’, function () { return {restrict: ’AE’,scope: { datas: '='},templateUrl: '/templates/profitSearch.jsp',controller: function ($scope, $http) {$http({ url: ’doSearch.req’, method: ’POST’, data: $scope.searchObject}).success(function (response, header, config, status) { $scope.datas = response.content;}).error(function (response, header, config, status) {});}

指令在页面直接应用:

<profit-search></profit-search>

但是这样赋值是错误的:$compile:nonassign

怎么破呢?我上面不是用了双向绑定了吗?

问题解答

回答1:

你指令上使用的时候没有赋值, 试试改成这样。

scope: { datas: '=?' },

或者给指令赋值

<profit-search datas='datas'></profit-search>

https://docs.angularjs.org/error/$compile/nonassign

回答2:

你有必要写指令么?乱来!胡乱写指令耽误时间不说,性能也好不了。直接在service里边写个请求应该就能解决问题了。

回答3:

<profit-search datas=’datas’></profit-search>

相关文章: