Na stronie Rozpoczęcie pracy z polimerem widzimy przykład polimeru w akcji:
<html>
<head>
<!-- 1. Shim missing platform features -->
<script src="polymer-all/platform/platform.js"></script>
<!-- 2. Load a component -->
<link rel="import" href="x-foo.html">
</head>
<body>
<!-- 3. Declare the component by its tag. -->
<x-foo></x-foo>
</body>
</html>
To, co zauważysz, jest <x-foo></x-foo>
definiowane przez platform.js
i x-foo.html
.
Wygląda na to, że jest to odpowiednik modułu dyrektywy w AngularJS:
angular.module('xfoo', [])
.controller('X-Foo', ['$scope',function($scope) {
$scope.text = 'hey hey!';
})
.directive('x-foo', function() {
return {
restrict: 'EA',
replace: true,
controller: 'X-Foo',
templateUrl: '/views/x-foo.html',
link: function(scope, controller) {
}
};
});
Jaka jest różnica między nimi?
Jakie problemy rozwiązuje Polymer, których AngularJS nie ma lub nie będzie?
Czy są plany związania Polymer z AngularJS w przyszłości?
javascript
angularjs
polymer
Dan Kanze
źródło
źródło
Odpowiedzi:
Nie jesteś pierwszym, który zadaje to pytanie :) Pozwól, że wyjaśnię kilka rzeczy, zanim przejdę do twoich pytań.
Polymer
webcomponents.js
to biblioteka, która zawiera kilka wypełniaczy dla różnych interfejsów API W3C, które wchodzą w skład komponentu Web Components. To są:<template>
Lewy klawisz nawigacyjny w dokumentacji ( polimer-project.org ) zawiera stronę dla wszystkich tych „technologii platform”. Każda z tych stron ma również wskaźnik do pojedynczego wypełnienia.
<link rel="import" href="x-foo.html">
jest importem HTML. Importowanie jest przydatnym narzędziem do włączania HTML w innym HTML. Możesz dołączyć<script>
,<link>
, znaczników, czy cokolwiek innego w imporcie.Nic nie „linkuje”
<x-foo>
do x-foo.html. W twoim przykładzie przyjęto, że definicja elementu niestandardowego<x-foo>
(np.<element name="x-foo">
) Jest zdefiniowana w x-foo.html. Gdy przeglądarka zobaczy tę definicję, zostanie zarejestrowana jako nowy element.Na pytania!
Jaka jest różnica między Angular a Polymer?
Część tego omówiliśmy w naszym filmie z pytaniami i odpowiedziami . Ogólnie rzecz biorąc, Polymer jest biblioteką, której celem jest wykorzystanie (i pokazanie, jak używać) składników sieci Web. Jego podstawą są elementy niestandardowe (np. Wszystko, co budujesz, jest komponentem sieciowym) i ewoluuje wraz z rozwojem sieci. W tym celu obsługujemy tylko najnowszą wersję nowoczesnych przeglądarek.
Użyję tego obrazu, aby opisać cały stos architektury Polymera:
Warstwa RED: jutrzejszą sieć otrzymujemy dzięki zestawowi wypełnień. Należy pamiętać, że biblioteki te z czasem znikają, gdy przeglądarki przyjmują nowe interfejsy API.
ŻÓŁTA warstwa: Posyp odrobiną cukru polimerem.js. Ta warstwa to nasza opinia na temat wspólnego korzystania z określonych interfejsów API. Dodaje także takie elementy, jak wiązanie danych, cukier syntaktyczny, obserwatory zmian, publikowane właściwości ... Uważamy, że te rzeczy są pomocne w tworzeniu aplikacji opartych na komponentach internetowych.
ZIELONY: Kompleksowy zestaw elementów interfejsu użytkownika (zielona warstwa) jest nadal w toku. Będą to komponenty sieciowe, które wykorzystują wszystkie czerwone + żółte warstwy.
Dyrektywy kątowe a elementy niestandardowe?
Zobacz Alex Russella odpowiedź . Zasadniczo Shadow DOM pozwala komponować fragmenty HTML, ale jest także narzędziem do enkapsulacji tego HTML. Jest to zasadniczo nowa koncepcja w Internecie i coś, co inne ramy wykorzystają.
Jakie problemy rozwiązuje Polymer, których AngularJS nie ma lub nie będzie?
Podobieństwa: szablony deklaratywne, powiązanie danych.
Różnice: Angular ma interfejsy API wysokiego poziomu dla usług, filtrów, animacji itp., Obsługuje IE8, i na tym etapie jest znacznie bardziej niezawodną strukturą do budowania aplikacji produkcyjnych. Polimer dopiero zaczyna się w fazie alfa.
Czy są plany związania Polymer z AngularJS w przyszłości?
To osobne projekty . To powiedziawszy, zarówno zespoły Angular, jak i Ember ogłosiły , że ostatecznie przestawią się na używanie bazowych interfejsów API platformy we własnych ramach.
^ To jest ogromna wygrana IMO. W świecie, w którym programiści mają potężne narzędzia (Shadow DOM, Custom Elements), autorzy frameworków mogą również wykorzystywać te prymitywne elementy do tworzenia lepszych frameworków. Większość z nich obecnie przechodzi przez świetne obręcze, aby „wykonać zadanie”.
AKTUALIZACJA:
Jest naprawdę świetny artykuł na ten temat: „ Oto różnica między polimerem a kątem ”
źródło
Na twoje pytanie:
Z oficjalnego konta AngularJS na Twitterze: „angularjs użyje polimeru do swoich widżetów. To wygrana-wygrana”
źródło: https://twitter.com/angularjs/status/335417160438542337
źródło
Are there plans to tie Polymer in with AngularJS in the future?
Myślę, że dobrym pomysłem jest zacytowanie oryginalnego postu z zespołu AngularJS, którego nie uważasz ?W tym filmie 2 facetów z AngularJS rozmawiało o różnicach i podobieństwach dotyczących tych dwóch frameworków (AngularJS 1.2 i Beyond).
Te linki prowadzą do prawidłowych pytań i odpowiedzi:
źródło
1 i 2) Komponenty polimerowe mają zakres ze względu na ich ukryte drzewo w cieniu. Oznacza to, że ich styl i zachowanie nie mogą wykrwawić się. Angular nie jest objęty tą konkretną dyrektywą, którą tworzysz jak polimerowy komponent sieciowy. Dyrektywa kątowa może być w konflikcie z czymś w twoim globalnym zasięgu. IMO korzyść, jaką uzyskasz z polimeru, to to, co wyjaśniłem .. modułowe komponenty, które mają zakres css i JavaScript do tego konkretnego komponentu, którego nic nie może dotknąć. Nietykalny DOM!
Można tworzyć dyrektywy kątowe, aby można było dodawać adnotacje do elementu o kilku funkcjach. W przypadku elementów sieci polimerowych tak nie jest. Jeśli chcesz połączyć funkcjonalność komponentów, dołącz dwa komponenty do innego komponentu (lub zawiń je w innym komponencie) lub możesz rozszerzyć istniejący komponent. Pamiętaj, że główną różnicą nadal jest to, że każdy komponent jest objęty komponentami z sieci polimerowej. Możesz współdzielić pliki css i js z kilku komponentów lub możesz je wstawiać.
3) Tak, Angular planuje wprowadzić polimer w wersji 2+ według Roba Dodsona i Erica Bidelmana
To zabawne, że nikt tutaj nie wspomniał o zasięgu słowa. Myślę, że to jedna z głównych różnic.
Istnieje wiele różnic, ale mają one również wiele wspólnego, jeśli chodzi o tworzenie modułowej funkcjonalności Lego podobnej do aplikacji. Myślę, że można bezpiecznie powiedzieć, że Angular byłby ramą aplikacji, a polimer mógłby pewnego dnia żyć w tej samej aplikacji wraz z dyrektywami, przy czym główną różnicą jest zakres, ale polimer może zastępować wiele z twoich obecnych dyrektyw. Ale nie widzę powodu, dla którego Angular nie mógł działać w obecnej postaci i zawierać również składniki polimerowe.
Czytając ponownie odpowiedzi, pisząc to, zauważyłem, że Eric Bidelman (ebidel) ukrył to w swojej odpowiedzi :
„Shadow DOM pozwala komponować fragmenty HTML, ale jest także narzędziem do enkapsulacji tego HTML”.
Aby wyrazić uznanie tam, gdzie należny jest kredyt, otrzymałem odpowiedzi od wysłuchania wielu wywiadów z Robem Dodsonem i Ericiem Bidelmanem . Ale czuję, że odpowiedź nie została sformułowana, aby dać temu facetowi zrozumienie, którego chciał. Powiedziawszy to, myślę, że dotknąłem odpowiedzi, której szuka, ale w żaden sposób nie posiadam więcej informacji na ten temat niż Rob Dodson i Eric Bidelman
Oto moje główne źródła informacji, które zebrałem.
JavaScript Jabber - Polymer z Robem Dodsonem i Erikiem Bidelmanem
Shop Talk Show - Komponenty sieciowe z Robem Dodsonem
źródło
normalize.css
, to nie normalizuje się w cieniu? Więc muszę osobno znormalizować każdy taki element, bez możliwości zrobienia tego raz? Czy to dobrze?normalize.css
arkusze lub inne arkusze oparte na znacznikach), co ponownie jest łatwo osiągalne bez Shadow DOM. Z pewnością nie idealna izolacja, ale prob. działa w 95% przypadków użycia, przynajmniej tych, o których myślę.„ Komponenty sieciowe ” to nowy zestaw standardów, który obejmuje HTML 5, zaprojektowany w celu zapewnienia elementów składowych wielokrotnego użytku do aplikacji internetowych.
Przeglądarki są w różnych stanach wdrażania specyfikacji „Komponentów internetowych”, dlatego jest zbyt wcześnie, aby pisać HTML przy użyciu Komponentów internetowych.
Ale niestety! Polimer na ratunek! Polymer to biblioteka, która zapewnia warstwę abstrakcji w kodzie HTML, umożliwiając korzystanie z interfejsu API Web Components API, tak jakby był w pełni zaimplementowany we wszystkich przeglądarkach. Nazywa się to napełnianiem poli , a zespół Polymer dystrybuuje tę bibliotekę jako webcomponents.js . Nazywało się to kiedyś platform.js btw.
Ale Polymer to coś więcej niż biblioteka wypełniania stron dla komponentów internetowych ...
Wszystkie elementy można dostosowywać i rozszerzać. Są one używane jako elementy składowe wszystkiego - od widżetów społecznościowych, animacji po klientów Web API.
Polimer jest raczej biblioteką niż szkieletem.
Polimer nie obsługuje takich elementów, jak trasy, zakres zastosowania, kontrolery itp.
Chociaż istnieją pewne nakładki między Polymer i AngularJS, nie są one takie same. W rzeczywistości zespół AngularJS wspomniał o wykorzystaniu bibliotek Polymer w nadchodzących wydaniach.
Zauważ również, że polimer jest nadal uważany za „krwawiący brzeg”, podczas gdy AngularJS stabilizuje się.
Ciekawie będzie obserwować ewolucję obu tych projektów Google!
źródło
Myślę, że z praktycznego punktu widzenia funkcja szablonu dyrektyw kątowych i metodologia komponentu sieciowego wykorzystywana przez polimer spełniają to samo zadanie. Główne różnice, jakie widzę, to to, że polimer wykorzystuje internetowe interfejsy API, aby zawierać fragmenty HTML, bardziej poprawny pod względem składniowym i uproszczony sposób osiągnięcia tego, co Angular robi programowo podczas renderowania szablonów. Polimer jest jednak, jak stwierdzono, małym szkieletem do budowania deklaratywnych i interaktywnych szablonów przy użyciu komponentów. Udostępniono go wyłącznie do celów projektowania interfejsu użytkownika i jest obsługiwany tylko w najnowocześniejszych przeglądarkach. AngularJS jest kompletnym środowiskiem MVC zaprojektowanym do deklaratywności aplikacji internetowych za pomocą powiązań danych, zależności i dyrektyw. To dwa zupełnie różne zwierzęta. Na twoje pytanie Wydaje mi się, że w tym momencie nie będziesz czerpać większych korzyści z używania polimeru nad kątownikiem, oprócz posiadania dziesiątek gotowych komponentów, jednak nadal wymagałoby to przeniesienia ich do dyrektyw kątowych. Jednak w przyszłości, gdy interfejsy API sieci staną się bardziej zaawansowane, składniki sieciowe całkowicie wyeliminują potrzebę programowego definiowania i budowania szablonów, ponieważ przeglądarka będzie mogła je po prostu włączyć w podobny sposób, jak obsługuje pliki javascript lub css.
źródło
MVVM (widok modelu, widok modelu), który oferuje Angular, nie stanowi problemu, który Polymer zamierza rozwiązać. Komponowalny i wielokrotnego użytku, który dają ci dyrektywy Angular (niestandardowy tag + powiązana kombinacja logiczna), jest bardziej rozsądnym porównaniem, gdy rozważasz porównanie Angular i Polymer. Angular jest i pozostanie szerszą ramą służącą celom.
źródło
Do użytkownika: niewiele. Za pomocą obu możesz tworzyć niesamowite aplikacje.
Do programisty: używają zupełnie innej składni, więc każde rozwiązanie ma dość stromą krzywą uczenia się. Angular istnieje już dłużej i ma OGROMNĄ społeczność, więc trudno będzie znaleźć problemy, które nie zostały rozwiązane.
Do architekta: bardzo inny. Angular to platforma aplikacji odpowiedzialna za wszystkie aspekty twojego życia. Ma nawet dyrektywy zintegrowane pionowo, na wypadek gdybyś chciał mieć funkcje podobne do komponentów. Z drugiej strony polimer jest bardziej podobny do tego, jak korzystasz. Chcesz modalnego, na pewno, chcesz interaktywnego widżetu, nie ma problemu, chcesz obsługi tras, możemy to zrobić. Polimer jest również bardziej przenośny, ponieważ Angular wymaga aplikacji Angular do ponownego wykorzystania dyrektyw. Pomysł z Polimerem jest bardziej modulujący i będzie działał w innych aplikacjach, nawet aplikacjach Angular.
Polimer to podejście zmierzające do wykorzystania nowych standardów komponentów sieciowych. Jeśli funkcje takie jak elementy niestandardowe, Shadow DOM i import HTML są obsługiwane lokalnie, głupotą byłoby nie korzystać z nich. Obecnie większość funkcji komponentu WWW nie jest powszechnie obsługiwana ( obecny stan ), więc Polymer działa jak podkładka lub mostek. Trochę jak polifill (w rzeczywistości używa polypełniaczy).
Używamy Angular i Polymer razem od ponad roku. Część decyzji w tej sprawie opierała się na obietnicach złożonych nam bezpośrednio przez zespół Polymer, że współpraca będzie możliwa. Zrezygnowaliśmy z tego pomysłu. Teraz przechodzimy na używanie wyłącznie Polimerów.
Aby to zrobić ponownie, prawdopodobnie nie zdecydowalibyśmy się na użycie Polimeru, zamiast tego czekaliśmy, aż dojrzeje. Biorąc to pod uwagę, Polymer ma swoje zalety (niektóre całkiem dobre) i wady (niektóre z nich są dość frustrujące), ale myślę, że jest to dyskusja na inny wątek.
źródło
Angularjs Dyrektywajest podejściem do tworzenia niestandardowych elementów. możesz zdefiniować nowe tagi niestandardowe za pomocą niestandardowych atrybutów. Polymer może to zrobić, ale zrobi to w ciekawy i prostszy sposób. Polimer w rzeczywistości nie jest szkieletem, to po prostu biblioteka. Ale potężna i niesamowita biblioteka, w której można się zakochać (tak jak ja). Polymer pozwala poznać natywną technologię komponentów sieciowych stworzoną przez w3c, którą przeglądarki internetowe ostatecznie implementują. Komponent web jest technologią przyszłości, ale polimer pozwala na korzystanie z tej technologii w tej chwili. Google Polymer to biblioteka, która zapewnia cukier syntaktyczny i wypełniacze do budowania elementy i aplikacje z komponentami sieciowymi. Pamiętaj, że powiedziałem, że polimer nie jest szkieletem i jest biblioteką, ale kiedy używasz polimeru, tak naprawdę twój szkielet to DOM. ten post dotyczył kątowego js ver 1 i polimeru. Pracowałem nad obiema z nich, to moje projekty i osobiście wolę polimer od angularjs. Ale wersja Angular 2 jest zupełnie inna w porównaniu z angularjs ver 1.Directive w Angular 2 ma inne znaczenie.
źródło
Dyrektywy kątowe są koncepcyjnie podobne do elementów niestandardowych, ale są implementowane bez użycia interfejsów API komponentów internetowych. Dyrektywy kątowe są sposobem na budowanie niestandardowych elementów, ale Polymer i specyfikacja Web Components są standardowym sposobem na to.
element polimerowy:
Dyrektywa kątowa:
źródło