不写一行代码,部署一个门户网站(基于Antd)

写在前面

最近准备帮一个朋友搞门户网站,之前自己学过点React以及蚂蚁的Ant Design框架。毕竟是门户网站,也不需要什么后端交互,也就是纯前端就行了,所以搞起来还好。用了框架就跟搭积木一样。

但是我实际搞起来之后发现,我连搭积木都懒得搭建,如果有不用写代码的方法就好了。终于,随眼一瞥,发现了antd官网底部相关资源有这么个首页模板集。

环境配置

需要node的环境,安装教程不过赘述,网上找。

我这里用的是windows下的安装,根据自己的环境找相应的安装方法。

模板编辑

网站地址:landing.ant.design/index-cn

这算是一个模板网站

同时它也提供了编辑器,下面也提供了一些模板,我们直接进入编辑器

可以看到,即使你不会代码,直接通过拖拽的方式进行组件的编辑,参数化的对样式和内容进行修改,也可以得到一个满意的效果,这个使用就不过多赘述了。

将设计好的代码下载下来后,解压出如下

Recat项目创建(可跳过)

官方给出了使用教程文档,建议参考creawte-react-app的这部分

landing.ant.design/docs/use/cr...

但是,这个还需要一堆依赖安装,修改一些代码,配置一下本地环境等等操作太麻烦了,我这里不过多赘述。因为我要用更傻瓜的方法。

开箱即用的部署

官方是给出了一个git仓库的

github.com/ant-motion/...

仓库中是已经配置好的react项目代码示例,我们现在下载下来,进入目录然后装一下依赖,如果太慢大家可以使用cnpm,网上找方法,我就不过多赘述。

npm install 

我这里是已经装过了,然后我们先运行示例的代码

sql 复制代码
npm start

可以看到,示例已经运行起来了,现在我们将示例替换成我们刚刚下载的Home文件夹

将src下的Home文件夹进行替换,重新运行

sql 复制代码
npm start

完美替换,无需写一行代码,就创造出自己的门户网站。

Nginx 部署

最终,我准备使用Nginx将它部署起来,先在项目目录进行打包成静态资源文件,得到build文件夹

arduino 复制代码
npm run build

后面,我将用虚拟机来安装nginx,做演示,安装nginx

apt install nginx

我这里已经安装过了,然后把刚刚的build文件夹移动到虚拟机上,最终我得到到了路径打包后的静态资源的路径 /home/ssremex/home_deme。

编辑nginx.conf

bash 复制代码
vim /etc/nginx/nginx.conf
bash 复制代码
server {
        listen 8088; # 更换成自己想监听的端口
        server_name 0.0.0.0; 
        root /home/ssremex/home_deme; # 更好你自己的路径
        location / {
                try_files $uri $uri/ /index.html;
        }
}

检查一下nginx配置

nginx -t

没有问题,重启nginx服务

sudo systemctl restart nginx

完美!

相关推荐
anyup_前端梦工厂2 小时前
了解几个 HTML 标签属性,实现优化页面加载性能
前端·html
前端御书房2 小时前
前端PDF转图片技术调研实战指南:从踩坑到高可用方案的深度解析
前端·javascript
2301_789169542 小时前
angular中使用animation.css实现翻转展示卡片正反两面效果
前端·css·angular.js
风口上的猪20153 小时前
thingboard告警信息格式美化
java·服务器·前端
程序员黄同学3 小时前
请谈谈 Vue 中的响应式原理,如何实现?
前端·javascript·vue.js
爱编程的小庄4 小时前
web网络安全:SQL 注入攻击
前端·sql·web安全
宁波阿成5 小时前
vue3里组件的v-model:value与v-model的区别
前端·javascript·vue.js
柯腾啊5 小时前
VSCode 中使用 Snippets 设置常用代码块
开发语言·前端·javascript·ide·vscode·编辑器·代码片段
weixin_535854225 小时前
oppo,汤臣倍健,康冠科技,高途教育25届春招内推
c语言·前端·嵌入式硬件·硬件工程·求职招聘
扣丁梦想家5 小时前
设计模式教程:装饰器模式(Decorator Pattern)
java·前端·装饰器模式