1.使用 Ghost 从零搭建博客系统
2.5分钟教你搭建个人博客,个人个人纯白嫖,博客博客花了一分钱你来打我
3.值得你阅读的源码源码Hexo个人博客搭建:不用购买服务器,不用购买域名,下载不要钱,个人个人不用敲代码等等!博客博客源码授权开发
4.nodejs个人博客载入页面开发教程
5.Hexo+Butterfly主题+Github搭建博客
6.简单!源码源码这可能是下载最快速的个人博客搭建姿势!|原创
使用 Ghost 从零搭建博客系统
使用 Ghost 从零搭建博客系统
Ghost 是个人个人一个开源的 CMS 博客系统,基于 Node.js 技术栈,博客博客专为团队设计,源码源码提供强大的下载功能、灵活性和高性能。个人个人
我们先在本地环境安装 Ghost。博客博客股性 源码访问 Ghost 官网教程,源码源码通过 Ghost-CLI 脚手架快速搭建。
全局安装 Ghost CLI,输入 `ghost -v` 检查是否安装成功。创建新目录,使用脚手架安装 Ghost。
遇到安装失败时,查看错误信息,确认 Node.js 版本是否支持 Ghost。使用 nvm 或 n 切换至支持的 Node.js 版本,如 .。重新执行安装命令,确保运行成功。js源码解读
使用浏览器访问本地服务器地址 `localhost:/ghost/`,完成管理员账号创建,并进入后台界面。设置网站名称、描述、时区和语言。通过内容目录结构了解项目的组织方式。
自定义语言设置,新建 locales 文件夹,在其中创建 en.json 和 zh.json 文件,进行翻译。编辑翻译文件,补全模板文件以支持国际化。ueditor 1.1.2源码使用 `ghost restart` 命令重启服务,使更改生效。
在服务器上安装 Ghost,选择 Docker 安装方式。拉取镜像,运行容器,确保正确配置域名和端口映射。在 nginx 配置中指向容器的端口。访问域名,查看 Ghost 站点。
在容器内执行 Ghost 命令时遇到权限问题。根据文档提示,创建普通用户并添加 `--allow-root` 参数,相册 asp源码以解决权限问题,顺利执行命令。
总结,本地和服务器环境下的 Ghost 安装均较为简单。搭建的博客站点基础功能已具备,后续可进行主题选择、汉化翻译、文章目录归档等个性化设置。Ghost 的开源特性使得用户可以根据需求定制功能,实现更多功能。后续文章将涵盖团队版的使用与协作方法。
5分钟教你搭建个人博客,纯白嫖,花了一分钱你来打我
搭建个人博客,我选择了一种经济且便捷的方式,仅花费一分钟,且全程无需花费一分钱。我推荐的是结合Github Pages和docsify的组合。
我的经验是,过去尝试过多种博客平台,如WordPress、Typecho和Hexo,以及不同类型的主机,但最终都因各种原因放弃了,如维护成本、数据迁移的复杂性等。我对博客的需求是免费且易于迁移。Github Pages和docsify完美满足了这些条件。docsify的一大优点是支持Markdown,特别适合程序员,无需生成HTML,只需写好Markdown文件,框架会自动处理成网页。
开始前,你需要有Git环境和Node.js,Windows用户可以参考相关教程。注册一个Github账号是必要的,因为我们将利用Github Pages部署。接下来,设置npm的:qingfeng/qingfeng.github.io.git
branch: master 看准了所有:后面有一个英文空格,没有会出错的。 3.5发布 配置完这些信息后可以敲命令了如图。两个命令分别为hexo generate和 hexo deploy(注意顺序不要乱) 完成这些操作之后你就可以点击http://qingfeng.github.io访问了。最后应该是类似这个样子的。 4 主题设置 选择一款适合你的主题hexo 默认的主题样式是 landscape,也许你希望使用更多样、更个性化的主题风格。在 github 上有许多开源的 hexo 主题,你只需要把它们克隆到 ~/blog/themes 目录下,并在 ~/blog/_config.yml 的 theme 属性中设置你希望使用的主题,然后重新生成页面部署即可。这里推荐几个在 github 上 star 数较高的主题: Yilia next 这些主题怎么配置在这里就不讲了,因为他们都是开源的而且项目本身介绍已经很详细。当然,如果你自己就是一名优秀的前端工程师,甚至可以自己定制一份属于自己独一无二的hexo-theme,你还可以把你的作品开源到 github 上供更多的 hexo用户使用与学习。nodejs个人博客数据分页开发教程
本文为大家分享了nodejs个人博客开发的数据分页,具体内容如下
控制器路由定义
首页路由:http://localhost:/
首页分页路由:http://localhost:/index/2
/
*** 首页控制器
*/
var router=express.Router();
/*每页条数*/
var pageSize=4;
/*首页*/
router.get('/',function(req,res,next){
var cid=0;
F.model("article").assignIndexData(cid,1,pageSize,res);
});
/*首页分页*/
router.get('/index/:page',function(req,res,next){
var currentPage=parseInt(req.params.page);
var cid=0;
F.model("article").assignIndexData(cid,currentPage,pageSize,res);
});
分类列表分页路由:http://localhost:/category/分类id/分页
/*分类页*/
router.get('/category/:cid/:page',function(req,res,next){
var cid=req.params.cid;
var currentPage=parseInt(req.params.page);
F.model("article").assignIndexData(cid,currentPage,pageSize,res);
});
模型数据部分
控制器调用article模型的assignIndexData()方法,参数:分类id,当前页,每页条数,响应对象
调用category模型的getAllList()方法得到分类list,参数:回调函数
调用article模型的getCount()方法得到总条数,参数:分类id,回调函数
调用article模型的getArticlePager()方法得到文章对象的数据list,参数:分类id,当前页,每页条数,回调函数
对上一页,下一页进行-1和+1,并进行判断,上一页应大于0,下一页应小于等于总页数(总条数/每页条数 向上取整)
把数据分配到模板上
/
*** 文章模型文件
*/
module.exports={
/*获取条数*/
getCount:function(categoryId,callback){
var condition="";
if(categoryId!=0){
condition="where category_id="+categoryId;
}
var sql="select count(*) num from article "+condition;
db.query(sql,callback);
},
/*获取分页数据*/
getArticlePager:function(categoryId,currentPage,pageSize,callback){
if(currentPage=0||!currentPage) currentPage=1;
var start=(currentPage-1)*pageSize;
var end=pageSize;
var condition="";
if(categoryId!=0){
condition="where category_id="+categoryId;
}
var sql="select * from article "+condition+" order by time desc limit "+start+","+end;
db.query(sql,callback);
},
/*归档*/
getArchives:function(callback){
db.query("select time from article order by time desc",callback);
},
/*分配首页数据*/
assignIndexData:function(cid,currentPage,pageSize,res){
var categoryModel=F.model("category");
var articleModel=this;
// 分类数据
categoryModel.getAllList(function(err,categoryList){
// 文章条数
articleModel.getCount(cid,function(err,nums){
// 文章分页
articleModel.getArticlePager(cid,currentPage,pageSize,function(err,articleList){
var nextPage=(currentPage+1)=Math.ceil(nums[0].num/pageSize) ? Math.ceil(nums[0].num/pageSize) : currentPage+1;
var prePage=(currentPage-1)=0 ? 1 : currentPage-1;
// 归档
articleModel.getArchives(function(err,allArticleTime){
var newArticleTime=[];
for(var i=0;i
newArticleTime.push(F.phpDate("y年m月",allArticleTime[i].time));
}
/*分配数据*/
var data={
categoryList:categoryList,
articleList:articleList,
cid:cid,
nextPage:nextPage==0 ? 1 : nextPage,
prePage:prePage,
allArticleTime:newArticleTime,
currentPage:currentPage
};
/*渲染模板*/
res.render("home/index",data);
});
});
});
});
}
};
模板部分
href="/category//index/" rel="external nofollow" 上一页
href="/category//index/" rel="external nofollow" 下一页
效果图: