实现一个 Code Pen:(一)项目初始化

sxkk20082年前知识分享380

前言

前段时间掘金上线了一个新功能 Code pen,可以在线写代码,浏览器就可以运行预览,在文章中就可以插入代码片段,对 web 开发者大有裨益,非常方便读者对文章的理解,笔者对这种在线实时编辑的功能充满了好奇,所以打算开发一个简易的 Code pen。

技术栈

  • Next.js
  • Tailwindcss
  • Uniapp 云数据库

初始化项目

使用以下命令初始化一个 next 项目

npx create-next-app next-code-pen
cd next-code-pen

安装 tailwindcss 相关包,初始化 tailwind.config.js

npm install -D tailwindcss postcss autoprefixer
npx tailwindcss init -p

修改 tailwind.config.js 配置,将代码移动到src目录下,这个是我的个人偏好

module.exports = {
  content: ['./src/**/*.{js,ts,jsx,tsx}'],
  theme: {
    extend: {},
  },
  plugins: [],
}

页面结构

用 Tailwind 来实现一个页面

有个好的 logo 才可以开始一个好的项目

<div className="flex justify-center items-center h-16 w-28">
  <svg
    className="w-10 h-10"
    viewBox="0 0 1024 1024"
    version="1.1"
    xmlns="http://www.w3.org/2000/svg"
  >
    <path
      d="M512 341.33333336c0-94.4 76.8-171.2 171.2-171.2 94.4 0 171.2 76.8 171.2 171.2s-76.8 171.2-171.2 171.2C588.8 512.53333336 512 435.73333336 512 341.33333336z"
      fill="#FF3C41"
    >path>
    <path
      d="M171.2 682.13333336c0-94.4 76.8-171.2 171.2-171.2H512v171.2C512 776.53333336 435.2 853.33333336 340.8 853.33333336s-169.6-76.8-169.6-171.2z"
      fill="#0EBEFF"
    >path>
    <path
      d="M171.2 341.33333336c0 94.4 76.8 171.2 171.2 171.2H512V170.13333336H340.8c-94.4 0-169.6 76.8-169.6 171.2z"
      fill="#FCD000"
    >path>
    <text fill="#fff" x="520" y="860" fontFamily="Verdana" fontSize="460">+text>
  svg>
  <span className="ml2 text-gray-50">CODEspan>
div>

效果

logo

这个 logo 部分来源figma,后面再加一个+,意味着后我们可以从它开始一些五彩斑斓的项目。

页面主体部分

我们先安装 react-split-pane, 把我们的页面拆分成几块,分为 HTML,CSS,JS,可以拖拽视窗大小,这个包依赖版本是 react16, 由于 react 是平滑升级,所以可以强制安装

npm i react-split-pane --force

使用 react-split-pane ,初始化页面结构, react-split-pane 是将页面拆分成 2 块,若要拆分成 3 块的话,要使用 2 次。

<SplitPane defaultSize="50%" split="vertical">
  <SplitPane split="horizontal" defaultSize="33%">
    <div className="overflow-hidden flex flex-col w-full">div>
    <SplitPane split="horizontal" defaultSize="50%">
      <div className="overflow-hidden flex flex-col  h-full w-full">div>
      <div className="overflow-hidden flex flex-col h-full w-full">div>
    SplitPane>
  SplitPane>
  <div className="bg-red-50 h-full overflow-hidden">div>
SplitPane>

效果

拖拽效果

预览地址:https://code.runjs.cool/pen/create

代码仓库:https://github.com/maqi1520/next-code-pen

至此项目初始化成功, 接下来将介绍 在 next 项目中使用 Monaco Editor,Monaco Editor 是 VS Code 中使用的开源代码编辑器, 拥有代码高亮和代码自动补全的功能。

若对你有帮助记得点个 star,感谢!

以上就是本文全部内容,希望这篇文章对大家有所帮助,也可以参考我往期的文章或者在评论区交流你的想法和心得,欢迎一起探索前端。

本文首发掘金平台,来源Ai知识分享博客

相关文章

2-3 分钟后会在屏幕上输出宝塔面板的登录地址,宝塔面板会随机生成用户名、密码和端口,我们需要把这些地址保存到本地,以免下次忘记。

接下来我们需要在云服务器上设置安全组或者防火墙,放行自动生成的端口。

腾讯云配置安全组

开通了端口,输入宝塔面板地址,输入用户名和密码就可以登录了 宝塔面板登录

域名解析

腾讯云域名解析

在你的域名服务商后台,将一个域名解析到 这台这台服务器 ip,解析完成后,你就可以使用域名访问了。

安装 PHP+mysql

登录后要先绑定一个宝塔账号,这个大家自行注册就可以了 选择系统推荐的 LNMP 环境 绑定成功后,我们来安装 PHP+mysql,系统会自动弹窗框让我们来选择环境,我这里选择 LNMP

  • 急速安装,安装时间极快(5-10 分钟),版本与稳定性略低于编译安装,适合快速部署测试
  • 编译安装,安装时间长(30 分钟到 2 小时),性能最大化,适合生产环境, 点击一键安装后,宝塔面板就会开始安装环境了

LNMP 环境安装进度 等待 10 分钟后,环境安装完成,当然有经验的同学可以自行安装 PHP+mysql 的环境,但是使用宝塔面板对新手比较友好。

访问IP显示会宝塔404页面 此时访问我们的 IP 就可以看到页面,说明我们的环境已经安装成功了。

安装微擎

微擎官网:https://www.we7.cc/

微擎官方文档:https://www.kancloud.cn/donknap/we7/136557

微擎源码地址:https://gitee.com/we7coreteam/pros

微擎是一款小程序和公众号管理系统,可以实现微信平台(mp.weixin.qq.com)不能实现的功能,例如商城,餐饮,酒店,汽车,门店,同城,各类行业解决方案,营销,推广,吸粉,游戏,物联网和人工智能等功能,这些应用大部分收费,也有免费的应用,大家可以在官网上搜索安装。

点击网站,添加网站,输入你自己的要解析的域名, 宝塔面板添加网站

选择创建数据库,和 FTP,点击提交,此时输入我们的域名可以看到如下页面

宝塔默认创建的页面

说明我们的网站创建成功了。

安装微擎框架

在网站 ftp 目录下上传微擎框架的源码 上传微擎框架源码

上传完成后点击 zip 文件解压

设置网站默认站点

点击默认站点,设置我们刚才创建的网站

输入IP,开始安装微擎 输入 IP 地址,就可以进入微擎的安装页面了。 微擎安装页面检查环境

安装过程中会检查 PHP 环境要求,若检查不成功,我们需要修改相应的 PHP info 文件。

微擎配置数据库和密码

点击继续输入刚才创建的数据库信息,并且设置微擎后台密码

微擎安装完成

点击继续安装完成

《成语小秀才》部署教程

前言相信很多朋友都玩过这款小游戏,叫成语秀才,没体验过的朋友可以点击这里,扫码体验,这款小游戏开发起来还是比较困难的,首先要有一份海量的题库,然后在每道题都有不同的布局,我是一个非常喜欢学习的人,于是...

AI中台:打造智能化未来

AI中台:打造智能化未来

  近年来,人工智能(AI)的快速发展让各行各业都充满了无限可能。然而,虽然越来越多的企业开始关注AI技术的应用,但由于各自业务的不同,很难实现AI应用的有效复用和快速迭代。...

武汉创建国家级“区块链之城”提速增效

武汉创建国家级“区块链之城”提速增效

  链上荆楚,积厚成势。6月9日,第二届区块链服务网络(BSN)全球技能立异开展峰会在湖北武汉举行。会聚3家工业园、近150家区块链企业,武汉正加速建造国家级“区块链之城”。...

视频数据我找了“译学馆”中的一个API 作为我的初始数据,修改 main 函数来填充视频数据。

import example from './example.json" alt="使用 Next.js、 Prisma 和 PostgreSQL 全栈开发视频网站">

使用 Next.js、 Prisma 和 PostgreSQL 全栈开发视频网站

highlight: monokai theme: vuepress文章为稀土掘金技术社区首发签约文章,14 天内禁止转载,14 天后未获授权禁止转载,侵权必究!前言在前面的文章中,我们使用了 Not...

AI绘画生成器:你亲手创作的艺术品

AI绘画生成器:你亲手创作的艺术品

  近年来,AI技术的不断发展,让人工智能在艺术领域得以应用,尤其是AI绘画生成器网站,通过深度学习、神经网络等先进技术,将传统艺术与现代科技相结合,为广大用户提供了一个创作...

AI人工智能绘画:探索艺术与科技的融合

AI人工智能绘画:探索艺术与科技的融合

  随着科技的迅猛发展,人工智能的应用正在逐步改变着我们的生活方式和工作方式。在艺术领域中,人工智能也逐渐开始发挥重要的作用,尤其是在绘画领域中。AI人工智能绘画正日渐成为一...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。