我有以下字符串:
"/root/get";
现在我在上面的字符串中生成一个带有 1 个范围变量的查询字符串,但问题是当该变量的值发生变化时,新值不会自动在我的 URL 中更新。
您可以在下面的演示中看到我有 2 个按钮更新和检查。在更新中,我正在生成查询字符串,在检查按钮上,我正在更新范围变量的值,但这并没有反映在我的 URL 中。
我不明白为什么会这样。
当我单击检查按钮而不调用 generateQueryParameters 方法时的预期输出:
/root/get?no=2
var app = angular.module("myApp", []);
app.controller("myController", function ($scope) {
$scope.no = 1;
$scope.str = "/root/get";
$scope.update = function (data) {
$scope.str=generateQueryParameters($scope.str,
"no",$scope.no);
console.log($scope.str);
};
$scope.check = function () {
$scope.no=2;
console.log($scope.str);
};
function generateQueryParameters(url,name,value)
{
var re = new RegExp("([?&]" + name + "=)[^&]+", "");
function add(sep) {
url += sep + name + "=" + encodeURIComponent(value);
}
function change() {
url = url.replace(re, "$1" + encodeURIComponent(value));
}
if (url.indexOf("?") === -1) {
add("?");
} else {
if (re.test(url)) {
change();
} else {
add("&");
}
}
return url;
}
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<div ng-app="myApp" ng-controller="myController">
<input type="button" value="Update" ng-click="update()">
<input type="button" value="Check" ng-click="check()">
</div>
更新:我知道 $scope.no 的值何时会改变,所以我认为我不需要观察者,我不想再次调用。为什么 Angular 不会像 Angular 绑定那样generateParameters
自动更新我的值?str