Kategorien
Aktuell Allgemeines HTML Stuff

Should I use a framework or library?

At my current employer we do all kind of Web Applications. We call it Experience Technology. These customer user experiences have different needs. Sometimes we do static content deliverables like temporary marketing campaign pages, or knowledge bases that never get touched again. More often we do enterprise shopping experiences, catalogue maintenance, and other e-commerce platforms.

Asking someone of my team how to build their next customer user experience I get named: React, VUE, Svelte or at last, Angular. Normally no one tells me yet: Let’s do it native, let’s use Web Components.

Do I know why?

Maybe

Why the frameworks are so common and preferred is having some reasons:

  • They offer a community
  • Searching for an issue or supporting library for sure returns an Stackoverflow entry or an NPM library
  • There is great support by someone that has „already done this“
  • For Business: It is good to have something to sell that everyone knows

A quick poll

Doing a quick poll with our experience technologists hardens the opinion.

Showing React 58%, Angular 3%, VUE 15%, Native Web Components 7%. Other 13%

Observing the obvious

Using frameworks and libraries for everything, causes problems that could be prevented. Average weight of a page is increasing. Complexity of generated code too. Views of common frameworks and libraries are often ridiculous complicated and deep nested and adding libraries and grid systems is done with a click. Importing without seeing the direct deeper effect. On top of that, Designers create complex animations and placeholders and forget that we still have low-end devices to support and not an ideal-world fast internet. Accessibility and search, like find-ability is getting worse. When useless containers are nested and semantics are getting lost.

On top of all, GDPR compliance is bad to achieve as of often third parties are used in a way that makes it hard to know where your customers details are getting shared.

This directly leads me to the this ask: Do we at all need to use a framework or library? Can’t we use Web components?

Webcomponents.org tells a clear use case, but why does still no one considers it first place to use it as base in their projects?

Web components are a set of web platform APIs that allow you to create new custom, reusable, encapsulated HTML tags to use in web pages and web apps. Custom components and widgets build on the Web Component standards, will work across modern browsers, and can be used with any JavaScript library or framework that works with HTML.
Web components are based on existing web standards. Features to support web components are currently being added to the HTML and DOM specs, letting web developers easily extend HTML with new elements with encapsulated styling and custom behaviour.

Webcomponents.org

Would there be any advantage when using them instead of a framework? Long-term for sure. Imagine a situation where Facebook stops support for React, or Google for Angular. Sooner or later libraries might get outdated. The community for sure support it for some years, but it can stop. There is no guarantee that it works long. There are also new Libraries popping out every day.

As we started writing decoupled user experiences, using micro-services and micro-frontends, we forgot to enable us to create long lasting frontend code, that is maintainable. Instead of using native functionalities, write proper markup and getting accessible and search engine friendly.

We now create a dependency to a framework that is maybe out-dating soon. Any reason to do so?

Not really!

Frameworks and libraries should help us organizing and writing our code and deliverables, but not overtaking our thinking and tooling. It is not reasonable that we deliver whole applications to clients browsers, when the contents never or only every view months change. We should instead build more meaningful smaller applications. We even need to render server side, using JavaScript.

A quick excursion on what Web Components are

Using Web components would allow us to get back to standards, using browser supported simple tooling.

So why should you consider Web components as complement for frameworks and libraries?

  • They are already a standard!
  • They work cross browser (Can I use it?)
  • They are simple and stand-alone
  • They are already used
  • They are future proof!

The details

Web components are the wrapper name for a set of techniques that create browser rendered interfaces. They are created through custom elements, shadow DOM, HTML templates and HTML modules. The latter is yet not widely adopted by browsers.

Custom Element

Setup a JavaScript file that contains the code for your custom element.

class MyCustomElement extends HTMLElement {    
  connectedCallback() {
    this.innerHTML = `<p>Some Text</p>`;
  }
}
window.customElements.define('my-custom-element',  MyCustomElement)

You need a DOM node that can initialise it.

<my-custom-element></my-custom-element>

Shadow DOM

With your custom element you can add coloured text in the context of other text paragraphs. You can capsule your styles that only belonging to the needed node.

const shadowRoot = document.getElementById('fetched').attachShadow({ mode: 'open' });
shadowRoot.innerHTML = `<style>
p {
  border: 1px solid red;
  padding: 5px;
}
</style>
<p id="paragraph">Paragraph using <slot></slot></p>`;

Create some HTML to connect your code with it.

<span id="fetched">Slot</span>
<p id="paragraph">Normal Text</p>

Virtual DOM like shown below will be generated.

<body>
  <span id="fetched">    
    <#shadow-root>
      <style>
      p {
        border: 1px solid red;
        padding: 5px;
      }
      </style>
      <p id="paragraph">Paragraph using Slot</p>
    </#shadow-root>
  </span>
  <p id="paragraph">Normal Text</p>
</body>

Use HTML Templates

Stay DRY. Use HTML templates. Look at the the above example. If you want to render more paragraphs, you can repeat your <p> or just use a <template>. It is obvious what is wet and what is dry.

You can use them together with custom elements and shadow root, or alone.

<template id="template">
  <p></p>
</template>
<section id="paragraphs"></section>

How to render a HTML template.

const paragraphs = document.getElementById('template');
const text = [
  { node: 'Text 1' },
  { node: 'Text 2' },
  { node: 'Text 3' }
];
text.forEach(text => {
  const domNode = document.importNode(paragraphs.content, true);
  domNode.querySelector('p').innerHTML = text.node;
  document.getElementById('paragraphs').appendChild(domNode);
});

Did I missed HTML Modules?

Nope. But they are currently considered. So let’s see.

What else to consider

Take also into account that all is maintained in a component library. Handled in a DSM provided by InVision, Figma, or Design Kits like Sketch. We need to ensure to reuse our code and Styles. Design Tokens help here. Amazon has Style Dictionary, but there are others. And ideally, have a direct connect to your repository. (More would be subject of a full own post)

But my client has IE11 as standard browser!

Ask them why! Seriously!

If they still insist, and maybe even have a dated soon to be replaced Edge: there are Polyfills available, they render the components as HTML for you.

Any other input?

More and more Frameworks and libraries arise that help generating your applications with Web components. They offer build in test ability, design libraries, pattern libraries and more. There are well established ones like Polymer or Stencil. You can find more on the web component page list. So if you do not want to do it manually. Use provided tools. 

What to do

There is no golden hammer that makes all your problems a nail. But you should consider re-usability, need of the current implementation, and how long it will exists. Then it can help you making a decision.

Static rendering for interims campaign pages, knowledge bases, and so on can improve SEO, size, and customer experience. Full blown SPA with a checkout or profile management, and a healthy mixture for catalogue can do their part on this.

But the base of all should be a Web component. Just do it.

Resources mentioned and used

Fun fact

Yes, you can also make Web components complicated.

Kategorien
Aktuell HTML Stuff

Clickjacking Kampagnen bei Google Adsense

Seitdem ich mich mit Advertisement und Performance Media beschäftige, stolpere ich immer mehr über die eklatanten Lücken die das System hat. Der folgende Beitrag bei Malwarebytes beschreibt anschaulich wie exzsiv mittlerweile betrogen und beschummelt wird. Jetzt könnte man sagen: „Mir doch egal, trifft doch eh nur die Reichen von Google oder Facebook“. Dem ist aber leider nicht so. Die Brands (Marken) bezahlen den ganzen Mist und die Publisher bekommen davon nur noch einen Bruchteil ab. Was das Ergebnis ist: Mehr Werbung, da weniger Reichweite, mehr Ausgaben der Brands und damit mehr Kosten auf der Werbeseite und damit teurere Produkte. Und wir haben im Ganzen als Nutzer rein gar nichts davon. Daher müssen wir anfangen ein besseres Netzwerk zu unterstützen. Wirklich lesenswert!

Clickjacking-Kampagne missbraucht Google Adsense, vermeide Werbebetrugsbots

 

Kategorien
Aktuell

Bosch Sensorchestra

(…) Können Bosch Geräte wirklich Musik machen?

So wie ein Orchester viel mehr ist als die Summe seiner Teile, gibt Bosch durch intelligente Vernetzung Produkten des täglichen Lebens eine neue Qualität. Unser SENSORCHESTRA stellt diese Vernetzung auf akustische Art und Weise dar – und macht so das Internet der Dinge, seine Kraft und sein Potential erlebbar. Bleiben Sie dran: dies ist erst der Auftakt. (…)

Besuche das Sensorchestra eines unserer aktuellen Projekte!

Kategorien
Aktuell Allgemeines Arbeitgeber

Mittagspause – Italian Gardens, London

Einfach mal Pause machen. Italian Gardens, London, Hydepark.

Kategorien
Aktuell

Es geht mal wieder ins UK…

Ich war jetzt fast drei Jahre nicht mehr im Office in London. Mal gespannt was sich geändert hat…

Kategorien
Aktuell Tagungen / Veranstaltungen

Beyond Tellerrand 2014

Morgen geht es los, mal sehen was bei rum kommt. Freue mich, mit fast allen Interactive Developern von Sapient zusammen informative Beiträge auf der beyond tellerrand 2014 zu sehen. Bis Morgen!

Kategorien
Aktuell Allgemeines

Wie kauft man ein Google Nexus 7 im Play Store aus Deutschland heraus?

[UPDATE] Jetzt endlich auch im Play Store in Deutschland!

Nachdem ich hier in Deutschland sitze und sehnsüchtig die Berichte über das Google Nexus 7 gelesen habe, die Engländer schon in den Genuß kommen und in den USA sowieso, fragte ich mich: „wie kann ich das Google Nexus 7 in Deutschland kaufen?“. Da ich gerade, im Gegensatz zu den letzten vier Jahren, nicht nach England komme, ein Problem. Die Wiederverkäufer bei eBay oder auch kleineren Online Shops hatten einfach zu hohe, unverschämte Preise. Mein Weg war also:

  1. Meldet Euch bei Borderlinx an, damit Ihr eine UK Adresse bekommt.
  2. Verbindet diese Adresse in Google Wallet Payment Methods mit einer der Kreditkarten mit der Ihr bei Google Wallet bezahlt (wenn der Account danach gesperrt wird, über den Service von Google wieder freischalten lassen)
  3. Sucht Euch einen VPN in UK, oder jeden anderen Weg der eine UK IP vorgaukelt (Stichwort Proxy etc)
  4. Geht in den Play Store und bestellt das Nexus 7 indem ihr an die Adresse in UK liefern lasst und wählt die mit der Borderlinx-Adresse verbundene Kreditkarte aus.
  5. Und ab. ;)

Keine Garantie, dass das bei Euch auch klappt. Mir hat es aber geholfen ;) Ich war schon ganz schön verzweifelt. Bis September hätte ich es nicht mehr ausgehalten. Wie das jetzt mit der Garantie ist, weiß ich nicht, denke aber, dass zumindest die Herstellergarantie über Asus gewährleistet sein sollte. Die Kosten von ~ £230 (290€) inklusive Versand durch Borderlinx sind noch akzeptabel. Wenn man bedenkt, dass das Ding bei uns später auch mindestens 250€ (plus Versand) kosten wird. (Und ich habe es zuerst ;o)

Kategorien
Aktuell Gedanken

London Riots

Irgendwie schon komisch. Da fährt man die normale Bahnlinie (Overground) von Shoreditch High Street nach Canada Water und bemerkt eigentlich nichts von den Ausschreitungen. Dann will man aber in den größten TESCO vor Ort und muss feststellen, dass dieser aus Sicherheitsgründen geschlossen hat. Da sind mir dann auch die halb vermummten Gestalten das erste mal aufgefallen. Macht nichts dachte ich, Dominos hat den Bringdienst. Ätschebätsch, im Apartment angekommen, liefern die auch nicht, wegen den Ausschreitungen.

Jetzt gerade im fünften Stock des Büros ist der Ausblick schon etwas apokalyptisch. So ziemlich in alle Himmelsrichtungen in die man schauen kann raucht es. Auf Bildern sieht man das glaube ich nicht zu gut, daher lasse ich es mal zu viele einzustellen, nur ein kleines:

Rauch am Horizont und Hubschrauber

 Klasse Map-Aufbereitung der aktuellen und zurückliegenden Brennpunkte.