Нов съм в angular и започвам да се боря с тази крива на обучение.
Проправям си път през FreeCodeCamp Zipline, за да направя приложение за търсене в wikipedia. Една от необходимите функции е търсене на живо с предложения за заглавия на статии, но изглежда не мога да го накарам да работи.
Създадох фабрика за извикване на API на wiki. Фабриката ще работи само веднъж и няма да се актуализира, когато се направят промени в полето за търсене. Предполагам, че не работи, защото фабриката не се извиква, когато са направени промени в полето за въвеждане, но всичко, което се опитах да поправя, изглежда не работи.
HTML
<section id="container" ng-app="wikiSearch" ng-controller="searchPanel" class="center">
<h1>Wikipedia Viewer</h1>
<input id="search" type="text" placeholder="search" ng-model="searchTerm" ng-model-options="{debounce: 300}"/>
<section id="results"><a href="/bg#" target="_blank" class="wiki-entry"> </a>
<!-- test code-->
<div>{{searchTerm}}</div>
<div>{{titleSearch}}</div>
</section>
</section>
Javascript
var app = angular.module('wikiSearch', []);
app.controller('searchPanel', [ '$scope', 'API', function ($scope, API) {
$scope.searchTerm = 'einstein';
$scope.titleSearch = {};
$scope.searchResults = {};
var api_base = "https://en.wikipedia.org/w/api.php?";
var fullParams = "format=json&action=query&generator=search&gsrnamespace=0&gsrlimit=30&prop=extracts&exintro&explaintext&exsentences=2&exlimit=max&gsrsearch="
//var titles = "format=json&action=query&generator=search&gsrnamespace=0&gsrlimit=8&gsrsearch="
var callback = "&callback=JSON_CALLBACK"
API.search(api_base + fullParams + $scope.searchTerm + callback).success(function (data) {
$scope.titleSearch = data;
});
}]);
app.factory('API', [ '$http', function ($http) {
return {
search: function(targetUrl) {
console.log(targetUrl);
return $http.jsonp(targetUrl);
}
}
}]);
Ето оригиналния codepen, който можете да разгледате: Codepen Project
Можете да видите, че всички промени в полето за търсене не водят до никакви промени в върнатите json данни. Фабриката се обажда само веднъж.
Нямам много разбиране за това как работи angular, но моето предположение беше, че фабриката ще се актуализира в обхвата с всяка промяна, направена в полето за въвеждане. Очевидно греша, но бих искал да знам точно защо и как да го поправя.