搜索
首页web前端css教程一个由社区驱动的站点,高度:建立该网站

一个由社区驱动的站点,高度:建立该网站

在上一篇文章中,我们探索了社区驱动网站的计划阶段。我们讨论了接受用户提交的众多注意事项,这些因素是从我的经验建筑风格阶段中汲取的。

现在,让我们潜入代码!我们将建立一个高高的设置,为您的社区(或个人)网站提供基础。

系列:

  1. 计划捐款
  2. 建立网站(当前文章)

本文涵盖:

  • 设置高度并创建开发和构建脚本。
  • 建议的配置自定义。
  • 定义自定义数据并合并多个数据源。
  • 使用Nunjucks创建布局和高度的布局链条。
  • 部署到Netlify。

项目愿景

想象一个平台,用户在其中提交猫和狗的照片,参加可爱比赛。

本文仅关注宠物提交;用户投票(易于使用无服务器功能实施)留下来供将来开发。用户提交宠物的个人资料,每周产生一个“战斗”,其中包含随机猫与主页上的随机狗。

高度设置

首先使用npm init初始化一个新项目,然后安装Eleventy:

 NPM安装 @11ty/升高

可选,修改package.json脚本部分:

 “脚本”:{
  “开发”:“高度 - 服务”,
  “构建”:“高度”
},,

这可以通过Browsersync Hot Rodading( npm run develop )和生产构建( npm run build )进行开发。

安装fast-glob以进行有效的数据处理:

 NPM安装 -  save-dev fast-Glob

目录结构

高架允许自定义输入和输出目录。在项目根部创建eleventy.js

模块。Exports= function(leventyConfig){
  返回 {
    dir:{
      输入:“ SRC”,
      输出:“公共”
    },,
  };
};

创建一个pets目录来存储宠物数据,进一步细分为cats dogs子目录:

 <code>pets/ cats/ dogs/</code>

每个宠物的数据将是一个带有以下模式的JSON文件:

 {
  “姓名”: ””,
  “ petcolor”:“”,
  “最爱食品”:“”,
  “ FairiteToy”:“”,
  “ photourl”:“”,
  “ ownername”:“”,
  “ ownertwitter”:“”
}

创建一个CONTRIBUTING.md文件(或README.md ),以指导用户发布提交指南和数据架构。请注意, favoriteFoodfavoriteToyownerTwitter是可选的。出于安全性和托管原因, photoURL应该是URL,而不是文件上传。

数据处理

_data目录中创建cats.js and dogs.js以将单个PET文件组合到数组中:

 // cats.js
const fastglob = require(“ fast-glob”);
const fs = require(“ fs”);

module.exports = async()=> {
  const catfiles =等待fastglob(“ ./ src/pets/cats/*。json”,{
    casesEnsitiveMatch:false,
  });

  令Cats = new Set();
  for(让猫猫的猫){
    const catdata = json.parse(fs.ReadFilesync(cat));
    cats.add(catdata);
  }

  返回[...猫];
};

dogs.js是相似的,用“狗”代替“猫”)。这种方法最大程度地减少了合并冲突。

数据输出和模板

将一些样本JSON文件添加到pets/catspets/dogs中。在src目录中创建index.njk

<h1 id="猫">猫</h1>

宠物档案页面和分页

src目录中创建cats.njkdogs.njk ,并使用分页前物质( cats.njk ):

 ---
分页:
  数据:猫
  别名:猫
  尺寸:1
永久链接:“ https://www.php.cn/link/543817ED62FA34E371BB2229D4F7B603F”
---

这为每个宠物生成单独的页面。

布局和计算数据

src/_includes base.njkpets.njk中创建。 base.njk提供HTML样板{{ content | safe }} 。添加layout: base.njk Front物质到index.njk 。还将layout: base.njk添加到pets.njk中,以进行布局链。

使用cats.njkdogs.njk中的eleventyComputed分享模板变量:

 ---
高度计算:
  标题:“ {{cat.name}}”
  petcolor:“ {{{cat.petcolor}}”
  fairmyfood:“ {{{cat.favoritefood}}”
  FairiteToy:“ {{{cat.favoriteToy}}””
  photourl:“ {{{cat.photourl}}”
  ownername:“ {{cat.ownername}}”
  ownertwitter:“ {{{cat.ownertwitter}}”
---

将内容添加到pets.njk中以显示PET数据。添加layout: pets.njkcats.njkdogs.njk

部署进行Netlify

部署网站以进行Netlify。配置NetLify从public目录中使用,并在合并上运行npm run buildnetlify.toml文件可以简化此过程。启用拉动请求的部署预览。

接受提交

审查贡献指南并制定分支保护规则。提交过程涉及分叉,克隆,创建JSON文件,进行更改,打开拉请请求和合并。

结论

这将创建一个具有自动部署的功能站点。进一步的增强功能包括电子邮件新闻通讯,社交媒体预览,评论系统和Netlify CMS。完整的示例可在GitHub上找到。

以上是一个由社区驱动的站点,高度:建立该网站的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
使用页面CMS进行静态站点内容管理使用页面CMS进行静态站点内容管理May 13, 2025 am 09:24 AM

我知道,我知道:有大量的内容管理系统选项可用,而我进行了几个测试,但实际上没有一个是一个,y&#039;知道吗?怪异的定价模型,艰难的自定义,有些甚至最终成为整个&

链接HTML中CSS文件的最终指南链接HTML中CSS文件的最终指南May 13, 2025 am 12:02 AM

链接CSS文件到HTML可以通过在HTML的部分使用元素实现。1)使用标签链接本地CSS文件。2)多个CSS文件可通过添加多个标签实现。3)外部CSS文件使用绝对URL链接,如。4)确保正确使用文件路径和CSS文件加载顺序,优化性能可使用CSS预处理器合并文件。

CSS Flexbox与网格:全面评论CSS Flexbox与网格:全面评论May 12, 2025 am 12:01 AM

选择Flexbox还是Grid取决于布局需求:1)Flexbox适用于一维布局,如导航栏;2)Grid适合二维布局,如杂志式布局。两者在项目中可结合使用,提升布局效果。

如何包括CSS文件:方法和最佳实践如何包括CSS文件:方法和最佳实践May 11, 2025 am 12:02 AM

包含CSS文件的最佳方法是使用标签在HTML的部分引入外部CSS文件。1.使用标签引入外部CSS文件,如。2.对于小型调整,可以使用内联CSS,但应谨慎使用。3.大型项目可使用CSS预处理器如Sass或Less,通过@import导入其他CSS文件。4.为了性能,应合并CSS文件并使用CDN,同时使用工具如CSSNano进行压缩。

Flexbox vs Grid:我应该学习两者吗?Flexbox vs Grid:我应该学习两者吗?May 10, 2025 am 12:01 AM

是的,youshouldlearnbothflexboxandgrid.1)flexboxisidealforone-demensional,flexiblelayoutslikenavigationmenus.2)gridexcelstcelsintwo-dimensional,confffferDesignssignssuchasmagagazineLayouts.3)blosebothenHancesSunHanceSlineHancesLayOutflexibilitibilitibilitibilitibilityAnderibilitibilityAndresponScormentilial anderingStruction

轨道力学(或我如何优化CSS KeyFrames动画)轨道力学(或我如何优化CSS KeyFrames动画)May 09, 2025 am 09:57 AM

重构自己的代码看起来是什么样的?约翰·瑞亚(John Rhea)挑选了他写的一个旧的CSS动画,并介绍了优化它的思维过程。

CSS动画:很难创建它们吗?CSS动画:很难创建它们吗?May 09, 2025 am 12:03 AM

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

@KeyFrames CSS:最常用的技巧@KeyFrames CSS:最常用的技巧May 08, 2025 am 12:13 AM

@keyframesispopularduetoitsversatoryand and powerincreatingsmoothcssanimations.keytricksinclude:1)definingsmoothtransitionsbetnestates,2)使用AnimatingmatematingmultationmatingMultationPropertiessimultane,3)使用使用4)使用BombingeNtibalibility,4)使用BombingingWithjavofofofofofoffo

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器