nl.hideout-lastation.com
Paradijs Voor Ontwerpers En Ontwikkelaars


Hoe een statische blog te bouwen met behulp van Assemble

Vandaag gaan we een kijkje nemen bij Assemble, een Grunt-plug-in waarmee we statische sites met gemak kunnen maken en beheren . Monteren kan enigszins lijken op Jekyll, maar het geeft meer flexibiliteit en functies aan de tafel die het krachtiger maken.

Permalink, Bootstrap Boilerplates en LESS-compiler zijn de functies die ervoor zorgen dat een vergelijkbaar hulpmiddel wordt samengesteld als een volwaardige CMS-toepassing. Hierin laten we u zien hoe u Assemble gebruikt om een ​​statische blog te maken .

Stap 1. Projectafhankelijkheid installeren

Assembleert vereist Grunt om te functioneren (verwijs naar onze vorige berichten op Node.js en Grunt als je verdere hulp nodig hebt). Nadat Node en Grunt allemaal zijn ingesteld, maakt u vervolgens een package.json bestand in de projectmap om de knooppuntpakketten op te geven die we zullen gebruiken om onze blog te bouwen.

Voeg de volgende code toe in package.json:

 {"devDependencies": {"assemble" ":" ~ 0.4.40 ", " grunt ":" ~ 0.4.5 ", " grunt-contrib-connect ":" ~ 0.8.0 ", " grunt-contrib-watch " : "^ 0.6.1"}} 

Deze coderegels in package.json vertellen Node dat ons project afhankelijk zal zijn van Grunt, Grunt Connect, Grunt Watch en Assemble. Nu zullen we deze pakketten installeren door dit commando via de Terminal uit te voeren.

 npm installeren 

Stap 2. Laad en registreer Grunt-taken

Nadat alle afhankelijkheden zijn gedownload, maakt u grunfile.js en plaatst u de volgende regels:

 module.exports = functie (grunt) {grunt.initConfig ({pkg: grunt.file.readJSON ('package.json')}); grunt.loadNpmTasks ( 'assembleren'); grunt.loadNpmTasks ( 'grunt-contrib-connect'); grunt.loadNpmTasks ( 'grunt-contrib-watch'); grunt.registerTask ('standaard', ['connect: livereload', 'assemble', 'watch']); }; 

De regels die we in gruntfile.js hierboven plaatsen, laden en registreren alleen de afhankelijkheden die we zojuist hebben gedownload via de opdracht npm install . We zullen deze taken later in de volgende stappen "laten werken".

Stap 3. Map- en bestandsstructuur

We zullen nu de map en bestandsstructuur van onze blog als volgt organiseren :

 MyBlog / package.json gruntfile.js app / layout / default.hbs inhoud / pagina / index.hbs blog / first-posting.hbs partials / 

Met Assemble kunnen we het bestand en de directoryorganisatie configureren via gruntfile.js. Maar laten we voorlopig de standaardconfiguratie bijbenen, zoals hierboven weergegeven.

Stap 4. De blog lay-out

In Assemble zetten Layouts de basis voor een pagina . In stap 3 hebben we een lay- MyBlog/app/layout/ gemaakt met de naam default.hbs in de MyBlog/app/layout/ map. De .hbs extensie wordt gebruikt omdat Assemble de .hbs Handlebars gebruikt.

De default.hbs wordt gebruikt door alle pagina's in de blog die naar dit bestand verwijst. Hierin zullen we Bootstrap via BootstrapCDN gebruiken om de stylingbasis voor onze blog in te stellen. We voegen vervolgens de volgende codes toe in default.hbs :

 Mijn blog 

MIJN BLOG

{{> instantie}}

Stap 5. De grunt-taken configureren

Maak als volgende stap een Gruntfile.js om directory's en bestanden voor Assemble compileren te configureren . Open Gruntfile.js en voeg de volgende codes toe in de sectie Grunt.initConfig :

 grunt.initConfig ({pkg: grunt.file.readJSON ('package.json'), bekijk: {assemble: {files: ['app / content / blog / *. hbs', 'app / content / pages / *. hbs ', ' app / layouts / *. hbs ', ' app / partials / *. hbs '], tasks: [' assemble ']}, livereload: {options: {livereload:' '}, files: ['. /dist/*.html ']}, }, assemble: {options: {layoutdir:' app / layouts ', flatten: true, layout:' default.hbs ', partials:' app / partials / *. hbs '}, pagina: {bestanden: {'dist /': ['app / inhoud / pagina / *. hbs']}}, blog: {files: {'dist /': ['app / content / blog / *. hbs ']}}} connect: {options: {port: 8800, // verander dit naar' 0.0.0.0 'om toegang te krijgen tot de server van buiten de hostnaam:' localhost ', livereload: 35728}, livereload: {options: {open : true, base: './dist'}}}}); 

Stap 6. Pagina en eerste bericht genereren

We kunnen nu een pagina bouwen . Laten we het index.hbs bestand openen in MyBlog/app/content/page/ map en de inhoud toevoegen.

Startpagina

Dit is onze startpagina.

Voer de opdracht grunt via de opdrachtprompt of de terminal. Deze opdracht genereert het index.hbs bestand in een html bestand en start het bestand onmiddellijk in de browser. Laten we naar het resultaat in de browser kijken.

We zullen ook de eerste post van onze blog genereren . Open de first-post.hbs in de MyBlog/app/content/blog/ map en leg de inhoud neer, zoals zo.

Eerste post

Ik ben de eerste post. Lorem ipsum dolor sit amet, consectetur adipiserende elit. Odio, esse, perferendis, earum in sunt voluptate officiis voluptates quam pariatur veritatis quis deleniti fugit expedita aliquam est repellendus autem dolor non?

Voer opnieuw de grunt opdracht uit en je ziet het bestand first-post.html gegenereerd in een nieuw gemaakte map met de naam dist . Navigeer naar localhost:8800/first-post.html in de browser, je zou moeten vinden dat de eerste post hetzelfde is als de afbeelding hieronder.

U kunt meer berichten maken door meer .hbs bestanden te maken en deze in de MyBlog/app/content/blog/ map te plaatsen.

Stap 7. Maak een lijst met blogberichten

Nu gaan we een lijst met berichten maken en deze in de blogzijbalk plaatsen . Om dit te doen, zullen we de Partiële functie van Assemble gebruiken. Een "gedeeltelijk" is een herbruikbaar fragment van codes dat op de andere pagina's kan worden opgenomen.

De zijbalk is bedoeld om een ​​lijst met onze blogberichten te bevatten, evenals de link naar het betreffende bericht. Laten we een nieuw bestand maken met de naam sidebar.hbs . Voeg de volgende code toe en sla deze op in de MyBlog/app/partials/ .

sidebar

{{#each pages}}
  • {{/elk}}

    Bel dan de Zijbalk gedeeltelijk in default.hbs, als volgt:

    {{> zijbalk}}

    De #each is een lus die al onze blogberichten in MyBlog/app/content/blog/ map zal vermelden. Het resultaat wordt hieronder getoond:

    Stap 8. Variabelen gebruiken

    Met Assemble kunnen we een variabele gebruiken met YAML-frontmateriaal. YFM (YAML front matter) is een optionele sectie die bovenaan een pagina wordt geplaatst en wordt gebruikt voor het onderhouden van metagegevens voor de pagina en de inhoud ervan . We zullen het gebruiken om de titel van het bericht te specificeren; open first-post.hbs en pas de code aan zoals:

     --- titel: bericht een --- 

    {{title}}

    blahblah ...

    De tag {{title}} wordt gevuld met 'Post One' die we bovenaan hebben gedefinieerd.

    Stap 9. Bestellingslijst met berichten

    Met Assemble kunnen we de lijst met berichten sorteren en sorteren op basis van de opgegeven 'term' . Als voorbeeld, hier zullen we onze blogberichten op de zijbalk bestellen op de datum. Laten we onze post aanpassen door datum op YML-frontmateriaal toe te voegen, zoals hieronder:

     --- Titel: Datum van post één: 2014-07-10 --- 

    Pas ook andere berichtbestanden aan in MyBlog/app/content/blog/ . Vervolgens geven we op de sidebar.hbs de datum onder de titel van het bericht weer. Pas de code als volgt aan:

      {{#withSort-pagina's "data.title"}}
    • Geplaatst op: {{formatDate data.date "% B% d, % Y"}}
    • {{/}} WithSort

    Het resultaat is de lijst in de zijbalk die op datum is gesorteerd.

    Conclusie

    Nu hebben we een eenvoudige blog gegenereerd met Assemble. Assemble kan worden gebruikt als een alternatieve tool om websites te bouwen zoals we je al hebben laten zien. En als u dat wilt, kunt u een gratis webhostingservice zoals Github-pagina's gebruiken of servers die Node.js zoals Heroku ondersteunen om uw site online te zetten.

    14 YouTube-kanalen voor de beste zelfstudies over fotografie

    14 YouTube-kanalen voor de beste zelfstudies over fotografie

    Leren fotografie kost tijd en het is des te leuker als je het in je eigen tempo kunt oppikken. In dergelijke situaties komt YouTube van pas.Er zijn tal van kanalen die zich aan dit onderwerp wijden, en veel die gericht zijn op degenen die nieuw zijn in het vak door de vele aspecten van fotografie op te splitsen in kleine, gemakkelijk te verwerken videosegmenten

    (Technische en ontwerptips)

    4 Formulierontwerp UX-tips die u moet weten (met voorbeelden)

    4 Formulierontwerp UX-tips die u moet weten (met voorbeelden)

    We denken vaak over formulieren als eenvoudig middel om gebruikersgegevens te verzamelen, maar ze zijn ook een manier, soms de enige manier waarop onze gebruikers contact met ons kunnen maken . Het is waarschijnlijk waanidee om te denken dat we kunnen zorgen dat gebruikers het leuk vinden om formulieren in te vullen, maar het is zeker mogelijk om oplossingen te vinden die hen niet te erg irriteren en ze te helpen bij het proces

    (Technische en ontwerptips)