• Stars
    star
    22,033
  • Rank 1,090 (Top 0.03 %)
  • Language
    HTML
  • License
    BSD 3-Clause "New...
  • Created about 12 years ago
  • Updated about 2 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Our original Web Component library.

Polymer

Build Status Published on npm Published on webcomponents.org

ℹ️ Note: This is the current stable version of the Polymer library. At Google I/O 2018 we announced a new Web Component base class, LitElement, as a successor to the PolymerElement base class in this library.

If you're starting a new project, we recommend that you consider using LitElement instead.

If you have a project you've built with an earlier version of the Polymer library, we recommend that you migrate to 3.0 for best compatibility with the JavaScript ecosystem. Thanks to the interoperability of Web Components, elements built with Polymer 3.0 and LitElement can be mixed and matched in the same app, so once you have updated your project to Polymer 3.0, you can migrate to LitElement incrementally, one element at a time. See our blog post on the Polymer Project roadmap for more information.

Polymer lets you build encapsulated, reusable Web Components that work just like standard HTML elements, to use in building web applications. Using a Web Component built with Polymer is as simple as importing its definition then using it like any other HTML element:

<!-- Import a component -->
<script src="https://unpkg.com/@polymer/paper-checkbox@next/paper-checkbox.js?module" type="module" ></script>

<!-- Use it like any other HTML element -->
<paper-checkbox>Web Components!</paper-checkbox>

Web Components are now implemented natively on Safari and Chrome (~70% of installed browsers), and run well on Firefox, Edge, and IE11 using polyfills. Read more below.

Getting started

  • The easiest way to try out Polymer is to use one of these online tools:

  • You can also save this HTML file to a local file and run it in any browser that supports JavaScript Modules.

  • When you're ready to use Polymer in a project, install it via npm. To run the project in the browser, a module-compatible toolchain is required. We recommend installing the Polymer CLI to and using its development server as follows.

    1. Add Polymer to your project:

      npm i @polymer/polymer

    2. Create an element by extending PolymerElement and calling customElements.define with your class (see the examples below).

    3. Install the Polymer CLI:

      npm i -g polymer-cli

    4. Run the development server and open a browser pointing to its URL:

      polymer serve --npm

    Polymer 3.0 is published on npm using JavaScript Modules. This means it can take advantage of the standard native JavaScript module loader available in all current major browsers.

    However, since Polymer uses npm conventions to reference dependencies by name, a light transform to rewrite specifiers to URLs is required to run in the browser. The polymer-cli's development server polymer serve, as well as polymer build (for building an optimized app for deployment) automatically handles this transform.

    Tools like webpack and Rollup can also be used to serve and/or bundle Polymer elements.

Minimal Example

  1. Create a class that extends PolymerElement.
  2. Implement a static properties getter that describes the element's public property/attribute API (these automatically become observed attributes).
  3. Then implement a template getter that returns an HTMLTemplateElement describing the element's rendering, including encapsulated styling and any property bindings.
  <script src="node_modules/@webcomponents/webcomponents-loader.js"></script>
  <script type="module">
    import {PolymerElement, html} from '@polymer/polymer';

    class MyElement extends PolymerElement {
      static get properties() { return { mood: String }}
      static get template() {
        return html`
          <style> .mood { color: green; } </style>
          Web Components are <span class="mood">[[mood]]</span>!
        `;
      }
    }

    customElements.define('my-element', MyElement);
  </script>

  <my-element mood="happy"></my-element>

Overview

Web components are an incredibly powerful new set of primitives baked into the web platform, and open up a whole new world of possibility when it comes to componentizing front-end code and easily creating powerful, immersive, app-like experiences on the web.

Polymer is a lightweight library built on top of the web standards-based Web Components APIs, and makes it easier to build your very own custom HTML elements. Creating reusable custom elements - and using elements built by others - can make building complex web applications easier and more efficient.

By being based on the Web Components APIs built in the browser (or polyfilled where needed), elements built with Polymer are:

  • Built from the platform up
  • Self-contained
  • Re-usable
  • Interoperable across frameworks

Among many ways to leverage custom elements, they can be particularly useful for building reusable UI components. Instead of continually re-building a specific navigation bar or button in different frameworks and for different projects, you can define this element once using Polymer, and then reuse it throughout your project or in any future project.

Polymer provides a declarative syntax to easily create your own custom elements, using all standard web technologies - define the structure of the element with HTML, style it with CSS, and add interactions to the element with JavaScript.

Polymer also provides optional two-way data-binding, meaning:

  1. When properties in the model for an element get updated, the element can update itself in response.
  2. When the element is updated internally, the changes can be propagated back to the model.

Polymer is designed to be flexible, lightweight, and close to the web platform - the library doesn't invent complex new abstractions and magic, but uses the best features of the web platform in straightforward ways to simply sugar the creation of custom elements.

About Polymer 3.0

Polymer 3.0 is now released to stable, and introduces a major change to how Polymer is distributed: from HTML Imports on Bower, to JS modules on npm. Otherwise, the API is almost entirely backward compatible with Polymer 2.0 (the only changes are removing APIs related to HTML Imports like importHref, and converting Polymer's API to be module-based rather than globals-based).

Migrating to Polymer 3.0 by hand is mostly mechanical:

  • Components should be defined in JS modules instead of in HTML
  • Templates should be encoded in JS modules using a static get template() getter on PolymerElement subclasses using the html tagged template literal function (which parses HTMLTemplateElements out of strings in JS) rather than using <template> elements in a <dom-module>
  • All dependencies should be imported JS module imports rather than HTML Imports.

However, the polymer-modulizer tool automates the vast majority of this migration work. Please see details on that repo for automated conversion of Polymer 2.0 apps and elements to Polymer 3.0.

👀 Looking for Polymer v2.x? Please see the v2 branch.

👀 Looking for Polymer v1.x? Please see the v1 branch.

Contributing

The Polymer team loves contributions from the community! Take a look at our contributing guide for more information on how to contribute. Please file issues on the Polymer issue tracker following the issue template and contributing guide issues.

Communicating with the Polymer team

Beyond GitHub, we try to have a variety of different lines of communication available:

License

The Polymer library uses a BSD-like license that is available here

More Repositories

1

polymer-starter-kit

A starting point for Polymer apps
JavaScript
2,457
star
2

pwa-starter-kit

Starter templates for building full-featured Progressive Web Apps from web components.
JavaScript
2,367
star
3

polymer-bundler

Moved to Polymer/tools monorepo
TypeScript
1,196
star
4

old-docs-site

Old Polymer site. Replaced by these repos: polymer-project.org, polymer-library-docs
HTML
1,022
star
5

shop

The Shop app
JavaScript
990
star
6

designer

Polymer Designer Tool
JavaScript
839
star
7

web-component-tester

Moved to Polymer/tools monorepo
TypeScript
566
star
8

polymer-cli

Moved to Polymer/tools monorepo
JavaScript
498
star
9

pwa-helpers

Small helper methods or mixins to help you build web apps.
TypeScript
440
star
10

tools

Polymer Tools Monorepo
TypeScript
430
star
11

prpl-server

⚠️Maintenance mode⚠️ An HTTP server for Node designed to serve PRPL apps in production.
TypeScript
425
star
12

news

Polymer News (Progress Web App Template)
HTML
263
star
13

polycasts

HTML
220
star
14

polyserve

Moved to Polymer/tools monorepo
TypeScript
192
star
15

polymer-analyzer

Moved to Polymer/tools monorepo
TypeScript
159
star
16

hn-polymer-2

Polymer Hacker News clone
HTML
158
star
17

polymer-modulizer

Moved to https://github.com/Polymer/tools/tree/master/packages/modulizer
HTML
143
star
18

polymer-build

Moved to Polymer/tools monorepo
TypeScript
103
star
19

polymer-decorators

TypeScript decorators for Polymer.
TypeScript
93
star
20

polymer-editor-service

Moved to Polymer/tools monorepo
TypeScript
76
star
21

vscode-plugin

Provides autocompletion, linting, and more for web components.
TypeScript
74
star
22

pwa-starter-kit-hn

TypeScript
70
star
23

lazy-imports

Declarative lazy HTML imports as a behavior.
HTML
63
star
24

polymer-css-build

JavaScript
40
star
25

polymer-linter

Moved to Polymer/tools monorepo
TypeScript
34
star
26

atom-plugin

Provides autocompletion, linting, and more for web components.
JavaScript
32
star
27

polymer-library-docs

Polymer library documentation site.
HTML
23
star
28

gen-typescript-declarations

Moved to Polymer/tools monorepo
TypeScript
21
star
29

wct-local

Moved to Polymer/tools monorepo
TypeScript
21
star
30

dom5

TypeScript
19
star
31

polymer-resin

XSS mitigation for Polymer webcomponents that uses safe html type contracts
JavaScript
18
star
32

wct-sauce

Moved to Polymer/tools monorepo
JavaScript
17
star
33

polymer-project.org

Polymer Project site & blog.
HTML
15
star
34

koa-node-resolve

Koa middleware that transforms Node package specifiers to relative paths
TypeScript
15
star
35

browser-capabilities

Moved to Polymer/tools monorepo
TypeScript
14
star
36

tattoo

Test All The Things Over and Over
TypeScript
12
star
37

koa-esm-transform

Middleware for Koa servers that transforms standard JavaScript modules to AMD modules for use with older browsers that don't support modules natively.
TypeScript
10
star
38

polymer-project-config

Moved to Polymer/tools monorepo
JavaScript
8
star
39

css-select-parse5-adapter

An adapter for the css-select package to allow querying of parse5 generated trees.
TypeScript
8
star
40

polymer-workspaces

Moved to https://github.com/Polymer/tools/tree/master/packages/workspaces
TypeScript
8
star
41

polymer.github.io

HTML
7
star
42

tools-sample-projects

Sample projects that Polymer tools should handle.
HTML
7
star
43

ar-logo

JavaScript
7
star
44

tools-common

Moved to Polymer/tools monorepo
JavaScript
6
star
45

benchmarks

Benchmarks for Polymer project libraries
JavaScript
6
star
46

plylog

A logger for the Polymer CLI toolchain
TypeScript
4
star
47

elements

A collection of elements made by the Polymer team
4
star
48

koa-karma-proxy

Simplified coordination of karma and upstream proxy server using the koa web framework.
TypeScript
4
star
49

mocha-suite-child

Runs mocha test suites defined in HTML documents and include the results as if they are part of the main context.
3
star
50

.allstar

2
star
51

tools-team

Issues for tools in general
2
star
52

polygit

Polygit
TypeScript
1
star
53

.github

1
star