Tattoo

Cats

Bass

Cooking

True Colors: A Decade

About Me

An engineer who doesn’t look like one

Photos of me with long hair

I’m a front-end developer, sometimes dabbling in product design and a bit of not-so-serious full-stack work.

I grew up in Chaozhou’s ancient town and now live in Guangzhou. I’ve always been surrounded by Lingnan and Hong Kong culture, and I mostly speak Cantonese and Teochew in daily life.

I’m into being on my own, raising cats, long hair, tattoos, rock & metal, and cooking — all the good stuff.

Learn more >

Recent Blog

Tech Insights, Product Design & Life Musings

Vue Picture Cropper 1.x Released: The Design Philosophy Behind It

Vue Picture Cropper 1.x Released: The Design Philosophy Behind It

During this Spring Festival holiday, I gave the vue-picture-cropper package a major update, mainly to address some long-standing design and engineering issues. Although it's a breaking change, the migration cost for users is low, and there are now more flexible usage patterns (e.g. composables). I also gathered some thoughts while rewriting the source code, and I'd like to share them in this post.

2026/2/24 17:05:02

Open Source Projects

Projects that I created or maintaining

zhihu-collection-helper

3

Zhihu Favorites Assistant can add articles from a column to favorites. It is suitable for situations where a large amount of content needs to be filled in the favorites at the initial stage of creation.

Program

@web-analytics/vue

9
1
367.03k

Website pageview analytics tool for Vue.js (Including VuePress , VitePress etc.) and multi-analytics-platform support.

Toolkit

@bassist/build-config

11
3
1.13k

Opinionated collection of common build tool configurations.

Configuration

@iso-639/data

2
9.22k

Contains code lists for ISO 639-1 and ISO 639-2 as well as multi-language support.

Toolkit

@bassist/release

11
3
4.47k

Simple GitHub release generator.

Toolkit

create-preset

47
3
130.57k

Provides the ability to quickly create preset projects.

Scaffold

refresh-token

11
3

The refreshToken scheme and demo based on OAuth 2.0 for Front end developer.

Tutorial

@web-analytics/core

9
1
370.91k

Website pageview analytics tool for framework-free and multi-analytics-platform support.

Toolkit

@bassist/changelog

11
3
6.49k

Simple CHANGELOG generator.

Toolkit

chengpeiquan.com

60
9

My personal website, base on React 19 and Next.js 15.

Template

vite-plugin-banner

113
6
11.25M

A Vite plugin that adds a banner comment to the header of each chunk file.

Bundling