Heim > Web-Frontend > js-Tutorial > Erklärung des AngularJS Phonecat-Beispiels

Erklärung des AngularJS Phonecat-Beispiels

高洛峰
Freigeben: 2016-12-06 13:09:31
Original
1085 Leute haben es durchsucht

Vorwort

Ich habe kürzlich einige Informationen über AngularJS auf der offiziellen Website gelesen, die ich nach einer Weile einfach nicht ertragen konnte Ich habe beschlossen, es selbst umzusetzen. Wenn es um Fragen geht, ist es auch eine gute Möglichkeit, im Inneren nach Antworten zu suchen. Egal wie viel Sie sagen oder sehen, es ist besser, es selbst zu tun, also fangen wir an.

Text

1. Layout

Die Seitenleiste der Homepage ist ein Eingabefeld und ein Dropdown-Feld, und die rechte Seite ist ein Die Homepage wird bei der Umsetzung nicht erweitert. Nehmen Sie einige Änderungen an der Detailseite vor, versuchen Sie sie zu vereinfachen und erwägen Sie das Hinzufügen eines benutzerdefinierten Befehls (Karussellbild).

2. Architekturanalyse

Überlegen Sie sich zunächst, welche Dienste Sie nutzen müssen.
Da es sich bei uns um eine einseitige Anwendung handelt, müssen wir $route und $location bereitstellen. Verwenden Sie den Dienst $resource, um Ressourcen abzurufen. Verwenden Sie den Dienst $filter, um die Homepage-Daten zu filtern und zu sortieren. Zusammenfassend:

1). Die Dienste $route und $location sind für die Routingverwaltung und Sprünge zuständig.
2). Der Dienst $resource ist für die Ressourcenbeschaffung verantwortlich.
3). Der Dienst $filter ist für das Filtern und Sortieren von Daten verantwortlich.

3. Startseite und Detailseitenansicht

1. Detailseitenansicht

<div class="main">
  <div class="side">
    <p>
      <label>Search:</label>
      <input ng-model="filterKey" type="text" style="width:150px; ">
    </p>
    <p>
      <label>Sort by:</label>
      <select ng-model="sortKey">
        <option value="price">price</option>
        <option value="name" ng-selected="true">name</option>
      </select>
    </p>
  </div>
  <div class="content">
    <ul>
      <li ng-repeat="item in data" ng-click="$location.path(&#39;detail/&#39;+item.id)">
        <img ng-src={{item.img}}>
        <div>
          <h2>名字:{{item.name}}</h2>
          <p>性能:{{item.title}}</p>
          <p>价格:{{item.price | currency}}</p>         
        </div>
      </li>
    </ul>
  </div>
</div>
Nach dem Login kopieren

4. Logikanalyse

<slide></slide>是一个自定义指令,实现轮播图的功能
 
<div class="detail">
  <slide links=&#39;links&#39; w=&#39;200&#39; h=&#39;200&#39;></slide>
  <div class="text">
    <h2>设备:{{data.name}}</h2>
    <p>性能:{{data.desc}}</p>
  </div>
</div>
Nach dem Login kopieren
1. Erklären Sie zunächst die Informationen der externen Ressource infor.json. Es ist ein Array, jedes Element des Arrays ist ein JSON-Objekt, das die folgenden Felder enthält:

2. Routenverwaltung ($route)

{
    "id" : 1,
    "name" : "aaa",
    "title" : "bbb",
    "desc" : "ccc",
    "img" : "img/a.jpg",
    "price" : 100,
    "showList" : "[{"url":"img/b.jpg"},{"url":"img/c.jpg"}]"
}
Nach dem Login kopieren

Wenn die Form ist http://localhost/phonecat/phone.html#/index lädt die Indexvorlage

m1.config([&#39;$routeProvider&#39;,function($routeProvider){
 
  $routeProvider
    .when(&#39;/index&#39;,{
      templateUrl : &#39;template/index.html&#39;,
      controller : &#39;index&#39;
    })
    .when(&#39;/detail/:str&#39;,{
      templateUrl : &#39;template/detail.html&#39;,
      controller : &#39;detail&#39; 
    })
    .otherwise({
      redirectTo : &#39;/index&#39;
    });
 
}]);
Nach dem Login kopieren
Wenn die Form http://localhost/phonecat/phone.html#/detail/0 ist, lädt die Detailvorlage

Der Standardwert ist http://localhost/phonecat/phone.html#/index

3. Logische Analyse der Startseite (Index)

Laden der Startseitenressourcen:

var arr = [];
var objRe = $resource(&#39;infor.json&#39;); 
$scope.data = arr = objRe.query(); //获得data数据后首页即可进行渲染
Nach dem Login kopieren

Filtern und Sortieren von Homepage-Daten:

  $scope.$watch(&#39;filterKey&#39;,function(){ //监听输入框的数据变化,完成数据的筛选
    if($scope.filterKey){
      $scope.data = $filter(&#39;filter&#39;)(arr,$scope.filterKey);
    }else{
      $scope.data = arr;
    } 
  })
 
  $scope.$watch(&#39;sortKey&#39;,function(){  //监听select下拉框的数据变化,完成数据的排序
    if($scope.sortKey){
      $scope.data = $filter(&#39;orderBy&#39;)($scope.data,$scope.sortKey);
    }else{
      $scope.data = arr;
    }
  })
 
 
//这里有个需要注意的地方,我们用一个数组arr作为媒介,避免bug
Nach dem Login kopieren

Klicken Sie auf die Liste, um Zur Detailseite springen:

$scope.$location = $location; //将$location挂载到$scope下,模板中便可使用$location提供的方法
Nach dem Login kopieren

Die Vorlage sieht wie folgt aus:

<li ng-repeat="item in data" ng-click="$location.path(&#39;detail/&#39;+item.id)">  --点击的时候将列表跳转到详情页
Nach dem Login kopieren

4. Logische Analyse der Detailseite

m1.controller(&#39;detail&#39;,[&#39;$scope&#39;,&#39;$resource&#39;,&#39;$location&#39;,function($scope,$resource,$location){
  var id = parseInt($location.path().substring(8));  //获取索引
  $resource(&#39;infor.json&#39;).query(function(data){
    $scope.data = data[id];
    $scope.links = eval($scope.data.showList);  //自定义指令需要用到此数据
  });
 
}]);
 
//注意:$resource.query()为异步操作。数据相关的逻辑需要在回调中完成,否则可能会出现数据undefined的情况。
Nach dem Login kopieren

5. Die benutzerdefinierte Funktion von AngularJS ist sehr leistungsstark und bietet eine Lösung für die komponentenbasierte Entwicklung. Eine Denkweise. Lassen Sie uns einfach eine Karussellkomponente implementieren.

Verwendungsbeispiel:

Die Vorlage (slide.html) lautet wie folgt :

<div class="slide">
 <ul>
   <li ng-repeat="item in links">
     <img ng-src={{item.url}}>
   </li>
 </ul>
</div>
Nach dem Login kopieren

m1.directive(&#39;slide&#39;,function(){
  return {
    restrict : &#39;E&#39;,
    templateUrl : &#39;template/slide.html&#39;,
    replace : true,
    scope : {
      links : &#39;=&#39;,
      w : &#39;@&#39;,
      h : &#39;@&#39;
    },
    link : function(scope,element,attris){
      setTimeout(function(){
        var w = scope.links.length * scope.w;
        var h = scope.h;
        var iNow = 0;
 
        $(element).css({&#39;width&#39;:scope.w,&#39;height&#39;:h,&#39;position&#39;:&#39;relative&#39;,&#39;overflow&#39;:&#39;hidden&#39;})
        $(element).find(&#39;ul&#39;).css({&#39;width&#39;:w,&#39;height&#39;:h,&#39;position&#39;:&#39;absolute&#39;});
        setTimeout(function(){
          $(element).find(&#39;li&#39;).css({&#39;width&#39;:scope.w,&#39;height&#39;:h,&#39;float&#39;:&#39;left&#39;});
          $(element).find(&#39;img&#39;).css({&#39;width&#39;:scope.w,&#39;height&#39;:h});      
        },0);
 
        setInterval(function(){
          iNow++;
          $(element).find(&#39;ul&#39;).animate({&#39;left&#39;:-iNow*scope.w},function(){
            if(iNow==scope.links.length-1){
              $(element).find(&#39;ul&#39;).css(&#39;left&#39;,0);
              iNow = 0; 
            } 
          });
        },1000)      
      },50)
 
    }
  } 
})
Nach dem Login kopieren
Fazit

AngularJS stellt uns viele nützliche Funktionen zur Verfügung, wie zum Beispiel Routing-Management , Datenfilterung usw. Leistungsstärkere Funktionen erfordern weitere Untersuchungen, und dieser Artikel ist nur ein guter Anfang.

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage