FATAL Something's wrong. Maybe you can find the solution here: https://hexo.io/docs/troubleshooting.html TypeError: code.split is not a function Please report this to https://github.com/markedjs/marked. at codeToThemedTokens (C:\PEN_Testing\environment\new_blog\node_modules\shiki\dist\index.js:3191:26) at Object.codeToHtml (C:\PEN_Testing\environment\new_blog\node_modules\shiki\dist\index.js:3212:20) at filterIntoShiki (C:\PEN_Testing\environment\new_blog\node_modules\hexo-plugin-aurora\lib\highlighter\index.js:56:32) at renderer.code (C:\PEN_Testing\environment\new_blog\node_modules\hexo-plugin-aurora\lib\highlighter\index.js:127:14) at renderer.<computed> [as code] (C:\PEN_Testing\environment\new_blog\node_modules\marked\lib\marked.cjs:2340:48) at _Parser.parse (C:\PEN_Testing\environment\new_blog\node_modules\marked\lib\marked.cjs:2031:42) at parse (C:\PEN_Testing\environment\new_blog\node_modules\marked\lib\marked.cjs:1991:23) at Marked.parse (C:\PEN_Testing\environment\new_blog\node_modules\marked\lib\marked.cjs:2484:28) at Function.marked [as parse] (C:\PEN_Testing\environment\new_blog\node_modules\marked\lib\marked.cjs:2518:27) at module.exports (C:\PEN_Testing\environment\new_blog\node_modules\hexo-renderer-marked\lib\renderer.js:279:27) at Hexo.tryCatcher (C:\PEN_Testing\environment\new_blog\node_modules\bluebird\js\release\util.js:16:23) at Hexo.<anonymous> (C:\PEN_Testing\environment\new_blog\node_modules\bluebird\js\release\method.js:15:34) at C:\PEN_Testing\environment\new_blog\node_modules\hexo\dist\hexo\render.js:73:28 at tryCatcher (C:\PEN_Testing\environment\new_blog\node_modules\bluebird\js\release\util.js:16:23) at Promise._settlePromiseFromHandler (C:\PEN_Testing\environment\new_blog\node_modules\bluebird\js\release\promise.js:547:31) at Promise._settlePromise (C:\PEN_Testing\environment\new_blog\node_modules\bluebird\js\release\promise.js:604:18) at Promise._settlePromiseCtx (C:\PEN_Testing\environment\new_blog\node_modules\bluebird\js\release\promise.js:641:10) at _drainQueueStep (C:\PEN_Testing\environment\new_blog\node_modules\bluebird\js\release\async.js:97:12) at _drainQueue (C:\PEN_Testing\environment\new_blog\node_modules\bluebird\js\release\async.js:86:9) at Async._drainQueues (C:\PEN_Testing\environment\new_blog\node_modules\bluebird\js\release\async.js:102:5) at Async.drainQueues [as _onImmediate] (C:\PEN_Testing\environment\new_blog\node_modules\bluebird\js\release\async.js:15:14) at process.processImmediate (node:internal/timers:483:21) 我在使用hexo建站,我安装了两个hexo,因为之前的hexo因为修改了太多配置,所以我想换个新的。我把旧hexo中的文章拿到新hexo中,出现了以上错误。

时间: 2025-03-10 17:00:17 浏览: 19

嗯,用户在使用Hexo建站时遇到了问题,错误信息是TypeError: code.split is not a function,并且提到了markedjs/marked的仓库需要报告。用户还提到他们安装了两个Hexo实例,把旧的文章迁移到新的Hexo后出现了这个问题。我需要先理解这个错误的原因,然后给出解决方案。

首先,错误发生在codeToThemedTokens函数中,这个函数属于shiki库,看起来是在处理代码块的高亮。错误提示code.split不是一个函数,说明传入的参数code可能不是一个字符串,导致split方法调用失败。可能是在渲染代码块的时候,传入的代码内容不是字符串类型,或者某些配置不正确。

用户提到他们从旧的Hexo迁移了文章到新的Hexo,所以问题可能出在文章的格式或配置上。可能是旧的文章中的代码块语法与新Hexo使用的插件(如hexo-plugin-aurora或hexo-renderer-marked)不兼容。或者,新Hexo安装的某个插件版本与旧文章中的写法有冲突。

接下来,我需要考虑常见的可能原因。例如,Markdown中的代码块语法是否正确?比如是否缺少语言声明,或者代码块语法错误。另外,可能是插件之间的兼容性问题,比如marked和shiki的版本问题。或者是hexo-plugin-aurora插件的配置问题,导致处理代码块时出错。

可能的解决步骤包括:检查文章中的代码块语法是否正确,确保代码块使用了正确的围栏式标记(三个反引号)并指定了语言;尝试禁用或更新相关的插件,比如hexo-plugin-aurora,或者检查其配置;清理Hexo缓存,重新安装依赖,确保所有插件都是最新且兼容的版本;还可以尝试将代码块替换为旧版本支持的语法,或者暂时移除有问题的文章,逐步排查。

另外,用户可能没有正确安装或配置语法高亮相关的插件,比如shiki需要额外的依赖或主题。也有可能是在迁移过程中,某些文件的格式被破坏,比如YAML front-matter中有语法错误,导致解析问题,从而影响了后续的代码块处理。

需要建议用户逐一排查这些可能性,从简单的步骤开始,比如检查代码块语法,清理缓存,更新插件,再到更复杂的步骤,比如禁用插件或检查配置。同时,提醒用户在遇到此类错误时,查看官方文档的故障排除部分,或者考虑回退到之前的稳定版本,以确定是否是版本升级带来的问题。这个错误通常是由于Hexo渲染Markdown代码块时语法冲突或插件版本不兼容导致的。以下是逐步排查和解决方案:


一、错误核心原因定位

从报错code.split is not a function可知:

  • 触发位置:shiki语法高亮库处理代码块时
  • 根本原因:代码块内容被传递为非字符串类型(可能是对象或空值)

二、关键排查步骤

1. 检查文章中的代码块语法

在所有迁移的文章中,确认代码块使用标准的围栏式语法:

​```语言类型(如js/python/bash)
代码内容
​```

⚠️ 缺少语言声明或反引号不匹配会引发解析错误

2. 清理Hexo缓存

hexo clean  # 删除public文件夹和缓存

3. 检查插件版本冲突

错误栈涉及hexo-plugin-auroramarked

npm list marked shiki hexo-plugin-aurora  # 查看插件版本

尝试回退版本(常见组合):

npm uninstall hexo-plugin-aurora
npm install marked@4.0.0 shiki@0.11.1

4. 临时禁用语法高亮

_config.yml中添加:

highlight:
  enable: false
prismjs:
  enable: false

5. 检查YAML Front-Matter

确保文章头部元数据没有特殊符号污染:

---
title: 正常标题  # 无冒号嵌套如 title: "含有:冒号"
date: 2023-01-01
---

三、进阶修复方案

方案A:修复shiki高亮逻辑

修改node_modules/shiki/dist/index.js约3191行:

// 原始代码(易错)
const code = params.code;

// 修改为(强制类型转换)
const code = String(params.code || '');

方案B:替换渲染引擎

改用更稳定的hexo-renderer-markdown-it

npm uninstall hexo-renderer-marked --save
npm install hexo-renderer-markdown-it --save

四、验证流程

  1. 新建测试文章只包含简单代码块
  2. 逐篇恢复旧文章,定位具体出错文件
  3. 使用hexo g --debug观察详细编译日志

五、技术原理说明

错误源于marked解析器与shiki的交互异常。当代码块内容被意外转换为非字符串类型(如undefined或对象)时,调用split()方法会触发TypeError。常见于:

  • 未闭合的HTML标签干扰解析
  • 特殊字符未转义
  • 插件版本API变更

建议优先通过版本锁定保持依赖稳定性,参考package.json

{
  "dependencies": {
    "hexo": "^6.3.0",
    "marked": "^4.0.18",
    "shiki": "^0.11.1"
  }
}
向AI提问 loading 发送消息图标

相关推荐

大家在看

recommend-type

AP5030DN-V200R010C00SPCf01.zip

华为AP固件AP5030DN_V200R010C00SPCf01.zip
recommend-type

华为MA5671光猫使用 华为MA5671补全shell 101版本可以补全shell,安装后自动补全,亲测好用,需要的可以下载

华为MA5671光猫使用 华为MA5671补全shell 101版本可以补全shell,安装后自动补全,亲测好用,需要的可以下载,企业光猫稳定性还是可以
recommend-type

视频转换芯片 TP9950 iic 驱动代码

TP9950 芯片是一款功能丰富的视频解码芯片,具有以下特点和功能: 高清视频解码:支持多种高清模拟视频格式解码,如支持高清传输视频接口(HD-TVI)视频,还能兼容 CVI、AHD、TVI 和 CVBS 等格式,最高支持 1 路 1080p@30fps 的视频输入 。 多通道输入与输出: 支持 4 路视频接入,并可通过一路输出。 可以通过 CSI 接口输出,也可以通过并行的 BT656 接口输出。 图像信号处理:对一致性和性能进行了大量的数字信号处理,所有控制回路均可编程,以实现最大的灵活性。所有像素数据均根据 SMPTE-296M 和 SMPTE-274M 标准进行线锁定采样,并且具有可编程的图像控制功能,以达到最佳的视频质量 。 双向数据通信:与兼容的编码器或集成的 ISP 与 HD-TVI 编码器和主机控制器一起工作时,支持在同一电缆上进行双向数据通信 。 集成 MIPI CSI-2 发射机:符合 MIPI 的视频数据传输标准,可方便地与其他符合 MIPI 标准的设备进行连接和通信 。 TP9950 芯片主要应用于需要进行高清视频传输和处理的领域,例如汽车电子(如车载监控、行车
recommend-type

通过CANopen 和 Elmo 通讯.pdf

通过CANopen 和 Elmo 通讯.pdf
recommend-type

ansys_ls-dyna基础理论与工程实践配书K文件.rar_K文件_LS-DYNA 文件_ansys ls-dyna_dy

适合新手的配书K文件,各种案例教学,全套提供。

最新推荐

recommend-type

解决fatal:remote error:You can't push to git://github.com/username/*.git问题的办法

在使用Git进行版本控制时,有时会遇到"fatal: remote error: You can't push to git://github.com/username/*.git"这样的错误提示。这通常意味着您试图向GitHub推送代码,但因为使用的协议不支持写入操作,导致推送...
recommend-type

64位linux 编译c提示gnu/stubs-32.h:No such file or directory的解决方法

例如,conf_init.c文件引用../include/MyTypes.h头文件,而这个头文件又引用/usr/include/stdint.h头文件,以此类推。只有正确地引用头文件,编译器才能正确地编译程序。 最后,总结来说,解决gnu/stubs-32.h文件不...
recommend-type

C++生成条形码的Zint库v2.4.3版本解析

标题“zint-2.4.3”指的可能是一款软件库的版本号,而该库的主要功能是生成条形码。软件库通常是程序员在开发应用软件时可以重用的代码集合。在这个情况下,"zint"可能是一个专用于生成条形码的C++类库,开发者可以通过该库在软件中添加条码生成功能。 描述中提到这个类库“简单方便”,意味着它应该具备易用性,即使是编程新手也能通过阅读网上的例程快速上手使用。这暗示了“zint”可能拥有良好的文档支持和示例代码,使得开发者可以不费太多力气就能在自己的项目中实现条形码生成功能。此外,描述中提到它是一个C++类库,这意味着它使用C++语言编写,并且向开发者提供了一套包含各种方法和属性的类来操作和生成条形码。 标签“条形码生成”非常明确地指出了这个类库的核心功能。条形码是一种广泛用于商品标识的机器可读的光学标签,它包含了一串代表特定信息的平行线或一组字符。在现代商业活动中,条形码被广泛应用于零售、物流、制造业等多个领域,用于跟踪商品信息、库存管理和提高销售流程的效率。通过使用“zint”这样的库,开发者可以为他们开发的应用程序添加生成和识别条形码的能力。 至于“压缩包子文件的文件名称列表”中的“zint-2.4.3”,这可能是指下载该软件库时,文件名是一个压缩包格式,且文件名为“zint-2.4.3”。文件压缩是一种将文件大小减小以便于存储和传输的技术,常见的压缩格式包括.zip、.rar等。开发者在下载这样的类库时,通常会得到一个压缩包,解压后才能使用其中的文件。 在详细学习和使用“zint”库时,开发者需要了解的几个关键知识点包括: 1. 条形码基础知识:了解条形码的不同类型(如UPC、EAN、Code 128、ISBN等),以及它们的使用场景和区别。 2. C++编程基础:由于“zint”是一个C++类库,开发者需要具备C++语言的基本知识,包括语法、类和对象的使用、以及内存管理。 3. 类库的安装和配置:通常包括将类库文件添加到项目中、配置编译器以便正确编译和链接库文件,可能还包括在项目中包含相应的头文件和库文件路径。 4. 代码实现:理解“zint”库提供的API和函数,学习如何调用这些函数来生成特定格式的条形码。 5. 错误处理:了解如何处理可能出现的错误,例如条形码生成失败、库函数调用错误等,并知道如何根据库的文档进行调试。 6. 性能优化:了解如何优化生成条形码的速度和效率,尤其是在需要生成大量条形码或在性能要求较高的应用场景下。 7. 安全性和合规性:确保生成的条形码遵守相应的行业标准和法规,尤其是在敏感信息编码方面。 开发者在掌握以上知识点后,应该能够在自己的C++项目中顺利使用“zint”库来生成条形码,并进一步将其应用到各种商业和工业应用中。
recommend-type

端面粗加工循环G代码:新手到专家的跨越式提升

# 摘要 本文系统地介绍了CNC编程中的端面粗加工循环G代码的应用和技巧。第一章简要概述了CNC编程与G代码的基础知识。第二章深入探讨了端面粗加工循环的理论基础、参数选择与高级技术应用。第三章通过编程实例与操作技巧的分析,强调了实践中的效率优化与质量控制。第四章提出端面粗加工循环的高级技巧与创新方法,包括循环嵌套、工具路径优化和数字化制造的自动化。最后一章结合案例研究和故障排除,提供了从设计到成品过程中的详细分析和解决策略。本文旨在为读者提供全面的端面粗加工循环知识,促进其在CNC加工中的有效运用和技术创新。 # 关键字 CNC编程;G代码;端面粗加工;编程实例;工具路径优化;自动化编程
recommend-type

QT程序自启动后,程序读文件内容显示时,无法显示内容

在Qt应用程序中,若希望程序自启动并加载文件内容展示出来,但却发现界面无法正确显示出应有数据的情况,通常可能是由于以下几个原因导致的问题。 ### 可能的原因及解决办法 #### 1. **路径问题** - 程序运行时的工作目录与开发环境中不同。当您设置相对路径去读取资源文件(如txt、json等配置文件)的时候,在实际部署环境下可能导致找不到正确的文件位置。 解决方案:明确使用绝对路径代替相对路径;或者调整工作目录到包含所需文件的位置再加载。 #### 示例代码: ```cpp QString filePath = QCoreApplication::applicati
recommend-type

Android SQLite数据库操作实例教程

在Android开发中,SQLite数据库是一个轻量级的关系数据库,它内嵌在应用程序中,不需要服务器进程,适用于Android这样的嵌入式系统。SQLite数据库支持标准的SQL语言,且具有良好的性能,适用于数据存储需求不是特别复杂的应用程序。 要使用SQLite数据库,我们通常需要通过Android SDK提供的SQLiteOpenHelper类来帮助管理数据库的创建、版本更新等操作。以下是基于标题和描述中提供的知识点,详细的介绍SQLite在Android中的使用方法: 1. 创建SQLite数据库: 在Android中,通常通过继承SQLiteOpenHelper类,并实现其onCreate()和onUpgrade()方法来创建和升级数据库。SQLiteOpenHelper类封装了打开和创建数据库的逻辑。 2. 数据库版本管理: SQLiteOpenHelper类需要在构造函数中传入应用程序的上下文(Context),数据库的名称,以及一个可选的工厂对象,还有一个表示当前数据库版本的整数。当数据库版本变化时,可以在这个版本号上进行升级处理。 3. 数据库操作: Android提供了一系列的API来进行数据库操作,包括插入、查询、更新和删除数据等。 - 插入数据:使用SQL语句INSERT INTO,或者使用ContentValues对象结合SQL语句来完成。 - 查询数据:使用SQL语句SELECT,结合Cursor对象来遍历查询结果集。 - 更新数据:使用SQL语句UPDATE,通过指定条件来更新数据库中的数据。 - 删除数据:使用SQL语句DELETE,通过指定条件来删除数据库中的数据。 4. 使用Cursor对象进行数据遍历: 当执行查询操作时,Android会返回一个Cursor对象,该对象是一个游标,用于遍历查询结果。通过Cursor可以读取查询返回的每一条记录的数据。 5. 数据库的CRUD操作示例: 下面是一个简单的SQLite数据库操作示例。 ```java // 创建数据库帮助类实例 MyDatabaseHelper dbHelper = new MyDatabaseHelper(context); SQLiteDatabase db = dbHelper.getWritableDatabase(); // 获取可写数据库对象 // 插入数据示例 ContentValues values = new ContentValues(); values.put("name", "John"); values.put("age", 26); long newRowId = db.insert("User", null, values); // 插入数据 // 查询数据示例 Cursor cursor = db.query("User", new String[] {"name", "age"}, null, null, null, null, null); while (cursor.moveToNext()) { String name = cursor.getString(cursor.getColumnIndex("name")); int age = cursor.getInt(cursor.getColumnIndex("age")); // 处理查询数据 } cursor.close(); // 关闭游标 // 更新数据示例 values.clear(); values.put("age", 27); db.update("User", values, "id = ?", new String[] {"1"}); // 更新条件为id=1的记录 // 删除数据示例 db.delete("User", "id = ?", new String[] {"1"}); // 删除id=1的记录 db.close(); // 关闭数据库 ``` 6. SQLite在Android Studio中的调试: 开发时可以通过Android Studio的Logcat日志输出进行调试,查看SQL执行情况。在Logcat中可以搜索SQL语句,查看执行结果。 7. 事务操作: SQLite支持事务操作,可以使用BEGIN TRANSACTION、COMMIT和ROLLBACK语句来确保数据的一致性。事务用于处理错误时的回滚操作,保证操作的原子性。 8. 数据库优化: Android开发中应关注SQLite数据库的性能优化,包括合理地设计表结构、索引、查询语句的优化,以及定期对数据库进行清理和维护。 以上知识点覆盖了SQLite数据库在Android平台上的基本操作和概念。通过上述例子和操作,开发者可以实现数据存储和管理的基本功能,并在实践中不断优化和调整,以满足应用程序具体的需求。
recommend-type

【数控车床编程的5个秘诀】:初学者的必学指南

# 摘要 数控车床编程是制造业中提高生产效率和加工精度的关键技术。本文从基础知识讲起,逐步深入到实战技巧和高级编程技术,探讨了编程过程中图纸理解、工具选择、误差控制、循环编程、多轴技术、螺纹和齿轮加工等方面。文章强调了优化策略的重要性,包括程序结构优化、编程效率提升以及故障诊断与预防。最后,文章展望了数控车床编程的未来趋势,包括智能化编程技术、CAD与CNC的集成以及教育和培训的新模式。
recommend-type

欧式范数

### 欧几里得范数的概念与计算 欧几里得范数(Euclidean Norm),也称为向量的2-范数,是一种常用的向量范数形式。它表示的是向量在欧几里得空间中的长度或大小。对于一个 \( n \)-维向量 \( \mathbf{x} = [x_1, x_2, ..., x_n]^T \),其欧几里得范数定义如下: \[ \|\mathbf{x}\|_2 = \sqrt{\sum_{i=1}^{n} |x_i|^2} \] 这实际上是向量各分量平方和的平方根[^4]。 #### 计算方法 假设有一个具体的二维向量 \( \mathbf{v} = [3, 4]^T \),则它的欧几里得范数
recommend-type

软件设计师考试复习资料及历年真题解析

标题:“软件设计师”指的是一种IT行业内的专业职称,通常要求从业者具备系统的软件开发知识、设计和编码能力,以及解决复杂软件问题的能力。软件设计师的角色不仅涉及编写代码,还涉及软件系统的架构设计、需求分析、技术选型、性能优化、团队协作等多个方面。这个职位通常要求通过相关的专业认证考试来证明其专业水平。 描述:“往年软件设计师考试的试题,课程讲义,详细的答案”暗示了这一文件内容的组成。它包括了历年来的软件设计师职业资格考试中出现的试题,这些试题可以涵盖软件设计、软件工程、编程语言、数据库系统、网络知识等多个领域,是软件设计师必须掌握的核心知识点。课程讲义则可能包括对应考试科目的教学材料,系统地介绍考试中出现的知识点和解题技巧。详细的答案部分则是对往年试题的解析,提供了正确的答题思路和方法,对备考者来说是极具参考价值的学习资源。 标签:“考试”指明了文件的用途和目标用户。这份资料是针对参加软件设计师职业资格考试的人准备的,用以辅助学习和复习,帮助考生掌握必要的知识点,提高解题能力。 压缩包子文件的文件名称列表中只有一个条目:“软件设计师考试”。从这个名称可以推测,该压缩文件内可能包含了一系列与软件设计师考试相关的材料,比如历年试题、课程讲义、答案解析、模拟测试、考试指南、备考建议等。这些材料为准备考试的考生提供了全面的学习资源。 从上述信息中,我们可以归纳出以下知识点: 1. 软件设计师角色要求:软件设计师不仅要有扎实的编程技能,还要对软件开发的全周期有深刻理解。包括但不限于需求分析、系统设计、编码实现、测试验证、部署上线等。此外,软件设计师还要具备良好的文档编写能力,能够清晰地表达设计思想和解决方案。 2. 软件设计师考试内容:考试一般会覆盖多个方面,包括但不限于软件工程基础、数据结构与算法、数据库管理系统、计算机网络、面向对象分析与设计、软件测试技术等。考生需要对这些理论知识有充分的理解,并能够应用这些知识解决实际问题。 3. 学习资源的准备与利用:历年试题和详细的答案解析是备考的重要工具。通过反复练习和回顾,考生可以熟悉考试的题型和难度,提高解题速度和准确性。课程讲义则是知识的系统化梳理,可以帮助考生建立知识体系,加深理解和记忆。考生还应该参考模拟测试,检验自己的备考效果。 4. 考试策略和技巧:备考软件设计师考试不仅需要全面掌握知识点,还需要了解考试策略和技巧。例如,如何在有限的时间内合理分配答题时间,如何针对不同类型的题目采取不同的解题方法等。考生可以通过模拟考试来练习时间管理,通过复习课程讲义和试题解析来熟悉应试技巧。 5. 持续学习和技能更新:软件行业是一个快速变化的领域,新的技术和开发方法不断涌现。因此,即使已经成为软件设计师,也需要持续学习和更新自己的技能,才能跟上行业发展的步伐。获取最新的行业资讯、参加在线课程、阅读专业书籍和论文、参与技术研讨会和交流活动都是提高自身专业素养的好方法。
recommend-type

STM8S001引脚定义及功能详解:深入掌握每个引脚的10大关键应用

# 摘要 本文对STM8S001微控制器进行了全面介绍,涵盖了引脚布局、电气特性、核心引脚功能、特殊功能引脚分析以及引脚应用案例。首先,本文简述了STM8S001的基本信息,随后深入探讨了其引脚布局特点和电气要求。核心引脚功能章节详细解析了电源、输入/输出和时钟引脚的作用及其设计注意事项。特殊功能引脚部分则专注于通信接口、定时器和调试引脚的使用。最后,本文通过多个应用案例展示了STM
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部