实战独立项目「几行字」:从想法到上线全过程

简介: 这个项目从想法、画原型、写前端、做设计、部署、搞后端、后台一整套,从想法到实现

想法



最开始是看到 毒鸡汤[1] 的项目(作者自己的域名已经不能访问,当初自己为了学习部署,也搞了一份,网址:[2]),觉得很有趣,简单又有趣


后来看到 今日诗词[3],这不是差不多吗,无非是提供了 API 调用罢了。


这两则的 star 数都超过了 1000+,这么简单的应用竟然这么受欢迎,有点羡慕嫉妒感

因为好奇,接触了 vite 、tailwindcss 等新技术,就想着用 vite 搭建一个 react 应用,样式用 tailwindcss 定制,于是就想要做个简单的应用,后来脑洞越想越大,就有了后续的规划,直接说规划


规划



这个项目从想法、画原型、写前端、做设计、部署、搞后端、后台一整套,从想法到实现


我最截止到写这篇文章时的规划是:


第一阶段:提出想法、画出原型、做好一个静态页面、部署到线上,即静态独立项目


第二阶段:用 vite + react 开发此项目,并添加功能点,如可选主题色、分享卡片等功能


第三阶段:数据不能裸泳,配置后端功能以及后台编辑功能


第四阶段:将其做成 Flutter 版本


第五阶段:将其做成小程序版本


这五个阶段笔者不会一口气做出来,有些东西只是想法,具体实施时困难肯定比想象中多的很


收集素材



之前混知乎,也关注了几个关于句子的问题,例如 你读过的最有力量的一段文字是什么?[4]有哪些适合摘抄的句子[5]  ,有些句子很喜欢,有些能受启发,与其这样,不如把有些高赞的句子收集起来,也做成像 毒鸡汤、今日诗词这样应用


于是乎,每天去知乎上手动收录素材,加上自己以前的库存,大概收集了 100 多条数据(写于第一阶段),


画原型



主要以简洁为主,能不要的东西统统不要,大致画出了这样


image.png

原型


写页面



初始化页面


npm init -y


为什么要弄功能?因为我们要用到 tailwind,它官方支持用这种方式,等 build 的时候会 tree-shake,能减少很多不必要的代码


后续可看 官网安装指南[6]


通过 npm 安装 Tailwind


npm install tailwindcss@latest postcss@latest autoprefixer@latest


作为 PostCSS 插件来添加 Tailwind


// postcss.config.js
module.exports = {
  plugins: {
    tailwindcss: {},
    autoprefixer: {},
  },
}


创建 tailwindcss 配置文件


npx tailwindcss init


这将会在您的工程根目录创建一个最小的 tailwind.config.js 文件。


// tailwind.config.js
module.exports = {
  purge: [],
  darkMode: false, // or 'media' or 'class'
  theme: {
    extend: {},
  },
  variants: {},
  plugins: [],
}


新建 tailwind.css


引入 tailwind 代码


@tailwind base;
@tailwind components;
@tailwind utilities;


新建 index.html


在代码中引入 css、以及编写 html 代码


这里我不细讲,因为花了不少时间,参数太多,大多数是看到符合自己原型的就拿来,然后删删改改


新建 data.js


之前收集了不少素材,将其导入到 data.js 中,并且编写以下逻辑,浏览器中读过的句子保存在本地存储里。句子是随机生成,如果随机生成的句子在本地存储中,那就重新生成。当所有的句子都存在本地存储中的话,就清空所有的本地存储。


因为我的内容有些不是一句话,而是一个数组,所有在插入内容时也需要判断,根据不同的情况做出不同的效果


这里遇到一些问题记录下,太久没有写原生,插入 html 的 api 忘记了,innerHTML 和 appendChild 的区别忘记了


innerHTML :可以插入一段 html,例如


我是 p 标签


appendChild :在内容末插入节点,要先创建标签,在插入


封装成三个方法,即拉取数据,存本地存储,插入网页


做设计



参考了一些别人做 logo 的建议,推荐比较多的是  logo 神器[7],我按照提示做下来是这样的设计

image.png

logo


我表示遗憾,从个人审美上来看,这种设计太傻瓜了,所以自己用 Photoshop 做了一个,


SEO 优化



favicon 处理


在 logo 中扣出 字,然后上传至 https://favicon.io/ 上,导出 favicon,


设置 header 信息


<head>
  <meta charset="UTF-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <title>几行字</title>
  <meta
    name="description"
    content="几行字给你温暖、几行字给你激励、几行字给你灵感"
  />
  <meta name="keywords" content="几行字,文案,几行世界" />
  <meta http-equiv="Cache-Control" content="no-siteapp" />
  <meta property="og:title" content="几行字" />
  <meta property="og:image" content="./favicon.ico" />
  <meta property="og:site_name" content="几行字" />
  <meta
    property="og:description"
    content="几行字,几行字给你温暖、几行字给你激励、几行字给你灵感"
  />
  <link rel="alternate icon" type="image/x-icon" href="favicon.ico" />
  <link rel="stylesheet" href="style.css" />
</head>


也写不出什么关键字来,先这样,后期有灵感了再补上


部署



笔者之前写过利用 Github Actions 部署前端 ,也成功部署过 毒鸡汤[8],大致流程如下


  1. 申请阿里云容器镜像服务


  1. 将代码推到 Github 仓库,触发 Github Actions


  1. Github Actions 中登录 阿里云容器镜像服务,将代码打包成一个镜像,并推到个人镜像站远端


       b.再登录服务器,执行拉取镜像脚本


主要逻辑是这样,但执行起来很麻烦,还不如直接部署来着算,什么直接部署,就是本地部署到线上,最有用的当属 now,也就是现在的 vercel[9],笔者之前部署过好几个项目,所以轻车熟路


直接部署上线:https://jihangzi-static.vercel.app/


在阿里云做一下映射:https://jihangzi.azhubaby.com/


第一阶段到此就告一段落


参考资料



[1] 毒鸡汤: https://github.com/egotong/nows


[2] 毒: http://du.azhubaby.com


[3] 今日诗词: https://www.jinrishici.com/


[4] 你读过的最有力量的一段文字是什么?: https://www.zhihu.com/question/47436256


[5] 有哪些适合摘抄的句子: https://www.zhihu.com/question/63165436


[6] 官网安装指南: https://www.tailwindcss.cn/docs/installation


[7] logo 神器: https://www.logosc.cn/


[8] Github Actions 部署前端: https://blog.azhubaby.com/2021/08/19/2021-08-19-GitHubActions-%E9%83%A8%E7%BD%B2%E5%89%8D%E7%AB%AF%E9%A1%B9%E7%9B%AE/


[9] 毒鸡汤: https://du.azhubaby.com/


[10] vercel: https://vercel.com

相关文章
|
6月前
|
监控 前端开发 测试技术
前端研发流程的深入解析:从构思到交付
前端研发流程的深入解析:从构思到交付
150 0
|
SQL 安全 网络安全
交易所开发测试版丨交易所系统开发规则玩法/架构设计/项目步骤/方案逻辑/案例解析/源码部署
The development process of the exchange system involves multiple steps and links. The following is the detailed process and steps for the development of the exchange system:
|
6天前
|
监控 前端开发 jenkins
Jenkins 在前端项目持续部署中的应用,包括其原理、流程以及具体的实现方法
本文深入探讨了Jenkins在前端项目持续部署中的应用,涵盖其基本原理、流程及具体实现方法。首先介绍了Jenkins的基本概念及其在自动化任务中的作用,随后详细解析了从前端代码提交到生产环境部署的全过程,包括构建、测试、部署等关键步骤。最后,强调了持续部署中的代码质量控制、环境一致性、监控预警及安全管理等注意事项,旨在帮助开发者高效、安全地实施持续部署。
22 5
|
1月前
|
前端开发 测试技术 程序员
在工作中会涉及到的几个环境(概念补充) 办公环境、开发环境、测试环境、线下环境、线上环境/生产环境都是什么,他们之间的关系?
本文解释了在职场中可能会接触到的不同环境,包括办公环境、开发环境、测试环境和生产环境(线上环境),以及它们之间的关系和重要性。
68 1
|
6月前
|
小程序 UED
人力资源小程序的设计与开发步骤
人力资源小程序的设计与开发步骤
|
3月前
|
移动开发 小程序 测试技术
项目管理和持续集成系统搭建问题之帮助以诺行管理任务和资源如何解决
项目管理和持续集成系统搭建问题之帮助以诺行管理任务和资源如何解决
36 2
|
Kubernetes 网络安全 数据安全/隐私保护
k3s部署全过程
k3s部署全过程
613 0
k3s部署全过程
|
敏捷开发 测试技术
推三返一开发稳定版丨推三返一项目系统开发详细指南/方案需求/步骤逻辑/流程功能/案例设计/技术架构/源码程序
推三返一系统开发是一种软件开发模式,也被称为迭代增量开发模式。它是一种敏捷开发方法的一种,通过将整个开发过程分为多个迭代周期,每个周期都会增加新的功能和特性,并在每个迭代周期结束后进行测试、反馈和修改。推三返一系统开发的核心思想是“推进三步,反馈一步”。
|
运维 测试技术 区块链
链动2+1模式系统开发指南流程丨成熟案例丨功能设计丨测试部署丨方案项目丨逻辑需求丨源码出售
链动2+1模式系统开发方案是指一个较为复杂的系统开发模式,其中包含两个公链和一个私链的组合。
|
监控 数据可视化 项目管理
多项目管理难在哪,多项目同时进行该如何做好进度管理?
对于项目经理来说,多项目并行推进的情况已是常态。从工作层面来说,不仅在各项目之间抢资源、资源冲突、资源分配不合理的情况,面对繁杂的工作很难保质保量。因此,对于项目的所有参与干系人来说,多项目的管理与执行更具挑战。