Saubere Technik für ein sauberes Netz - Kampf dem Spacerframe
und wie baut man so ein web?
Nicht nur um behinderten das Netz nutzbar zu machen, sondern auch auch aus ästhetischen Gründen ist Suchmaschinen) eines der wichtigsten Gebote. Sie spielt in der schnellen Darstellung, der maschinellen Indizierung Web:Www die tragende Rolle. Gutes Design ist wichtig, aber wirklich gutes Design ist auch barrierefrei. Wer Informationen in Bildern oder prosperitären großvolumigen Dateien versteckt, vergeht sich an der Ästethik. Schminken ist ein Kunst, vor allem im Netz.
Handwerk
Webseiten sind grundsätzlich in offenen und freien Formaten zu schreiben. Die Betonung liegt auf selbst zu schreiben! Niemand will das gewurschtel aus irgendwelchen Wysiwig-Editoren sehen. Ordentliche Arbeit ist Handarbeit. Nichts gegen Contentmanagemntsysteme, darum geht es hier nicht. Denn auch diese brauchen templates udn die sind eben in Handarbeit ztu erstellen.
html & css
.html kombiniert mit Css steht für schnelle, sauberer vielschichtige Webseiten. How Many HTML Elements Can You Name in 5 Minutes?
Warum ist logisches html sinnvoll, warum soll man nicht für alles ein div nehmen und dann hin und her schieben. Mit den (wenigen) logischen html Elementen können ''die Maschinen'' einfach besser umgehen, so gibts viele Beispiele
- eines der häufigsten Argumente für eine html Überschrift (h2) ist meistens die Lesbarkeit durch eine Suchmaschine, (auch wenn diese Tatsache auch wieder zu komischen Auswüchsen führt=
- letztens hab ich festgestellt das mein Druckertreiber einen ''tablehead'' als solchen erkennt und den Spaltenkopf auf jede gedruckte Seite schreibt;)
und natürlich javascript.
Responsive
kleine elektronische Geräte) für Mobile ist gar nicht so einfach, vor allem kann man soooo viel machen was oft gar nicht gut ist. Darum wäre wichtig
- Wiedererkennbarkeit: wenn man das breite Menü schon zusammen/auseinander schieben muss, dann bitte an der gleichen Stelle. Wichtig ist aber immer, dass ein Layout sich vernünftig, also für den Benutzer nachvollziehbar anpasst. Schließlich soll sich ein Besucher, der eine Seite zum ersten mal am Desktop-Computer aufruft auch noch zurechtfinden, wenn er die gleiche Seite am nächsten Tag auf seinem Smartphone wieder besucht.
- anscheinend soll man das Bürgermenü (☰) (noch?) weglassen
Persistenz
Persistenz ist so ein schönes Wort;) Aber bei aller der Frage nach rendereing, events und laufzeit. Es geht immer noch um Inhalte und die müssen irgendwo gespeichert werden
- file
- db
- mails
Maschine
CMS oder Framework
html und JS zu verstehen ist wichtig, genauso wie ein Schreiner ein Stück Holz auch mit Hand Werkzeugen bearbeiten können muss. Natürlich aber ist für vieles ein Content-Management-System eine strukturierte und arbeitserleichternde Anwendung.
Es ermöglicht vor allem den Inhalt (Texte erstellen, redigieren, kommentieren etc) von der Darstellung und der Funktion zu lösen. Was zwar nicht immer funktioniert und viele Enduser eben kein content einpflegen, aber könnten.
Ich selbst nutze inzwischen gern Wordpress, da die User schnell eigene normale Dokumente schreiben kann. So kann die klassiche Pressemitteilung, der Blogbeitrag, Stellen-Ausschreibung oder Newsletter aber auch die "statischere" Seite von der jeweiligen Fachperson geschrieben und veröffentlich werden. Ich kann mich dennoch ausenrum um Spezialitäten wie API-Anbindungen, Abhängikeiten etc kümmern.
Empfehlbar sind noch so Systeme MODx oder Drupal für speziellere Anwendung. Und im ''Im Endeffekt zählt aber nicht nur die reine Qualität, sondern eben auch die Verbreitung eines Systems, denn je mehr Entwickler sich auf eine Plattform einschießen, desto besser für den Kunden, weil er leichter gute Entwickler für sein laufendes Projekt findet...''
Was soll ein CMS können:
- Inhalt
- Einzelseiten (inkl Metaseiten, Systemseiten) und Listen (aus Kategorien)
- in einfachen html ohne unnötige classen und divsuppen
- eine vereinfachte Auszeichnungssprache am besten markdown
- URLs organisieren Clean URL, sparsame Kategorisierung)
- eine optionale Indexstruktur mit Tags oder Kategorien (keine aufzwingende)
- und ein mindestens ein frontside editor (verwurschtelte adminbackends kann man sich sparen)
- Zugriffsrechte
- optional fremdusermanagement (OpenID)
- Versionierung
- rss (von mir aus auch so nen automatic twitterdingens) Nicht nur blogs leben von der Veränderung
- redirect
- Fehlerverwaltung (404 etc)
- Suche (evtl extern)
- Kommentare (evtl extern Disqus Comment System)
- dann mit mit Spam Abwehr (CAPTCHA, dnsbl etc)
- nette Fetaures die nativ oder per plugin umsetzbar sind
- Table of Contents
- Katgorie in Seite auflisten (aka DPL)
Um Webseiten zu bauen nutz ich gern ,
- wordpress wenn es vor allem um regelmäßige Veröffentlichungen geht.
- wikis wenn user zusammenhängende Seiten bearbeiten sollen, denn ein Wiki folgt ganz dem dokumentenorientieretn Ansatz und der ist dem User einfach erklärbar. Wenn man editbutton und die Funktion für neue Seiten verstanden hat, weis er alles was er braucht. (In Joomla müsste er erst das backend und darin den Menüpunkt und die 2-3 dazugehörigen Contents finden dohhh). Für kleinere Webseiten gern Dokuwiki (z.B. barbarasailer.de, inicon.com), was den Vorteil hat keine Datenbank zu benötigen, für größere Webseiten aber auch gern Mediawiki (elta-rhine.de)
- am liebsten aber mein staticsitegenerator drfrederson, der kann das gleiche wie ein Wiki (editbutton) braucht wie dokuwiki keine Datenbank, nutzt markdown und kommt auf dem Server sogar ohne php aus. Außerdem kann man mehr konfigurieren.
Alternativ könnte man ein nosql-cms nutzen.
w3techs.com gibt eine ganz gute Übersicht wer wie was verwendet, aber leider ohne subdomains (dohh) sprich de.wikipedia.org wird nicht berücksichtigt.
Interaktion
Wer auf einer Webseite nicht nur lesen will, sondern auch eine bestimmte Prozess durchlaufen will beginnt eine Interaktion (vulgo web2.0) mit dieser
- Anmelden
- Shops
- Abstimmung (Polls oder doddle)
das kann natürlich auch durch Plugins erfüllt werden (wenn se sauber sind)
technisch:
- API
- saubere hooks für plugins
- MVC unf so kram
- theming
- natives jQuery (schon mal für fancyboxes und slideshows)
- https
- Export/Importe
- Backup
Seltene Zusatzfunktonen, die man nicht unbedingt immer braucht
- surveys
- shops
Webserv{er|ice}
Zwar können die meisten CMS immer nicht nur Texte ausliefern sondern auch Bilder, Dateien ausliefern und sogar verwalten, aber eben nicht alles. Oft ist es sehr praktikabel sich eine Webanwendung aus verschiedenen Webservice zu kombinieren.
Dateien und Bilder
Bilder sind ja auch nur Dateien
Was würde ich mir von einem Dateiserver erwarten:
- der upload sollte einerseits über (httpinterface (evtl auch im Bulk, was derzet nur per flash möglichist) aber auch zusätzlich +ber Filetransferschnitstellen wie ftp oder ssh möglich sein (wenn man mal richtig viel hat)
- Dateinamen wie ''Österreich im Herbst.jpg'' sollten automatisch auf eine URL lesbares und eventuell verändertes Format gebracht werden(z.B. ''2011_oesterreich_im_herbst.jpg'')
- die Gesamte URL verkürzen können
- sharding und syncing (homerechner, webfreigabe, handythumbs)
und was zusätzlich von einem Bilderserver und per Standardimageurl bilderapi
- resize per URL (dokuwiki) ''example.net/imager.php?pic=1234&width=250'' (auch für thumbs)
- Cropping auch per URL ''example.net/imager.php?pic=1234&width=250&height=50&x=190&y=125''
- zur Not auch per css
Und das alte spacergif bekommt man auch per base64, holft aber auch wenn man auf dem background linien braucht (mit repeat-x oder x kombinieren)
Galerien
Galerie ist nicht gleich Galerie, es gibt unterschiedliche Anforderungen
- hat man viele Bilder oder unterschiedliche (Einzlefotos von Personen anstatt ein paar Impressionen) so können thumbnails helfen galleria.io
- automatisches Abspielen der Bilder (autoplay)
- Übergänge
- Zoom (fancybox)
- URLs mit hashtag (''hausbau.html#2'')
Bildergalerien kann man in zwei Varianten angehen:
- Alle Bilder der Galerie als html-Bilder (z.B. mit einer html liste) und dann per JS als klickbare Galerie übereinander gelegt. galleria.io cdn ist ein einfaches Non-Obstrusiv Plugin.
- Bilder als html Links mit Ziel auf das Bild in voller Größe. Dabei kann man ein thumbnail als "linktext" nutzen.
Die linkversion hat den Vorteil dass nonJS user thumbnails bekommen und per tabbrowsing einzelne Bilder laden, während beid er img-Lösung immer alle Bilder vorgeladen werden.
Nicht verwenden sollte man flash oder JS-JSON Lösungen.
Entwickler
''In der Nacht als ich PHP gelernt habe, dachte ich: morgen baue ich das beste CMSCRMERPshopAPIservi-System ever!!'', die Ernüchterung das man nicht alle Problem so eifnach lösen kann ohnenicht gelich weider neue zu erschaffen kam am nächsten morgen. Bei manchen kommt sie nie.
Bei der Auswahl eines SoftwareSystems muss man vor allem den Erschaffer betrachten. Egal ob es sich um eine Herstellerfirma handelt oder eine Developercommunity-
- Developer: ist die Community oder Firma, groß genug um alle anstehenden Aufgaben zu erfüllen, aber klein genug um Feinstes abzuliefern
- Bekommt man ausreichenden unabhängigen und unterschiedlichen (Niveau) Support? Bei den wirklich großen OpenSource Systemen findet man mit einer Googel Anfragen meist mehr udn bessere Antworte als bei einem kommerziellen Support.
- Fehelermanagement, wo könne Fehler gemeldet werden (Bugtracker) und wie werden diese verarbeitet
- Schnittstelle
- Code: Alter, Qualität, Veränderung
Ein System selbst, innerhalb einer Firma aufzubauen, zu pflegen und anzupassen ist quasi unmöglich. Es fehlt meist an Entwickler (große Systeme haben 10 - 20 Vollzeitäquivalententwickler drauf). Und echtem harte feedback.
tectec
- Model View Controller
- Darstellung
- falsh nur wenns nicht anders geht (kopieren, derezit noch videos)
- logik jquery
- selektieren
- absenden
- sortieren
- persistenz
- weniger serialisieren (magento, wordpress, medaiwiki??)
- Dokumenten-Datenbanken die direkt JSON fressen
-
- CouchDB
-
- MongoDB
-
- ... ?
Qualität
Auf eine sauberer Einhaltung aller Seiten und css dateien ist zu achten. Das kann man natürlich einfach mit den Validierungstools des w3c.org überprüfen.
- validator.w3.org - Markup Validation Service
- jigsaw.w3.org - W3C CSS-Validierungsservice
- Offline multipage analyse
Weiter kann man sich mit browsershots.org screenshots mit den gängigsten browsern anzeigen lassen.