NPM đại cương - Xây dựng và đẩy package lên npm

NPM đại cương - Xây dựng và đẩy package lên npm

Bài viết trong chủ đề này:
  1. NPM đại cương - Tôi đã đẩy package lên npm như thế nào?
  2. NPM đại cương - Xây dựng và đẩy package lên npm
Tin ngắn hàng ngày dành cho bạn
  • .tgz chắc là dạng nén phổ biến mà mọi người hay dùng. Mình cũng thường nén các tệp dưới dạng tgz để dễ dàng di chuyển chúng đến khắp mọi nơi. Vừa nhanh, tiện lại tiết kiệm bộ nhớ.

    Mới đây có một công cụ mới gọi là .ptar gọi là bản "nâng cấp" của tgz. Nếu tgz chọn nén tất cả tệp được chỉ định thì ptar lại chọn lọc, tức là nếu có 2 tệp giống hệt nhau thì ptar chỉ cần nén 1 tệp, từ đó giúp giảm thời gian và dung lượng xuống nhiều hơn nữa.

    À đó là trong trường hợp có nhiều tệp giống nhau thôi nhé, còn khác nhau thì chưa chắc 😅

    » Xem thêm
  • Turso đang chuẩn bị tung ra bản Alpha đầu tiên cho phiên bản viết lại của SQLite bằng Rust. Họ tự tin đến mức trao thưởng cho bất kỳ ai tìm ra lỗi.

    Về lý do tại sao lại viết lại SQLite bằng Rust thì mọi người đọc trong bài viết, có nêu rất rõ 😄

    Introducing the first alpha of Turso: The next evolution of SQLite

    » Xem thêm
  • Cuối cùng thì Windsurf lại về tay Cognition.ai. Cho những ai chưa biết thì Cognition có sản phẩm tên là devin.ai - một dạng AI Agents mà họ gọi nó như là một "kỹ sư phần mềm". Hay nói cách khác là nó có thể làm việc như một lập trình viên độc lập.

    Cognition’s acquisition of Windsurf

    » Xem thêm

Vấn đề

Ở bài viết trước tôi đã tóm tắt quá trình hoàn thành việc đẩy một package lên npm, trong bài viết này tôi sẽ đi chi tiết cách làm package của tôi và cụ thể là một package cho vue.js cho việc nhập mã OTP.

Mã nguồn package tại github, và npm vue-otp-2.

Tạo khung

Ngay từ đầu tôi đã xác định làm package cho vue.js nên tôi đã tìm thấy một khung hỗ trợ cho việc đó đó là https://www.npmjs.com/package/vue-sfc-rollup.

Cụ thể package này giúp tôi khởi tạo một project với các thiết lập tối thiểu giúp cho việc phát triển nhanh chóng, nó bao gồm:

  • rollupjs.org - hỗ trợ cho việc build thư viện
  • Tích hợp sẵn babel.js
  • Một file SFC (Single File Component) mẫu để triển khai mã
  • ...

Viết logic

Về logic, package này chỉ đơn giản tạo ra một số lượng các ô vuông nhất định, mỗi ô vuông chỉ cho phép nhập một số. Khi nhập đủ các ô thì phát ra một event chứa dữ liệu đã nhập vào. Ngoài ra cũng có thể xoá dữ liệu trong các ô một cách liền mạch nữa, chứ không phải bấm vào từng ô để xoá đâu nhé :D.

Tư tưởng là vậy, trong quá trình làm tôi gặp một số vấn đề về xử lý sao cho package hoạt động mượt mà & phải không được gây ra bất kì lỗi lầm gì. Cuối cùng sau vài giờ làm việc thì tôi cũng đã đã hoàn thành được nó.

Kiểm thử

Sau khi hoàn thành tất cả mọi thứ thì tôi bắt đầu vào giai đoạn kiểm thử (test), nói là thế chứ thực chất trong quá trình viết code thì tôi vẫn phải test chứ.

Bước này là bước verify lại tất cả các case mà tôi có thể nghĩ ra, từ happy case cho đến những case ngoại lệ tôi đều kiểm tra lại hết. Vì không có nhiều thời gian nên tôi quyết định chọn con đường manual test. Nếu mọi người có thời gian thì có thể tìm hiểu thêm cách viết unit test thì sẽ khiến cho package "xịn xò" hơn đấy :D.

Tạo trang demo

Tất cả các case đều pass thì lúc này tôi tiến hành tạo một trang demo.

Demo khá là quan trọng vì nó sẽ giúp cho người dùng tương tác thực tế với package của bạn. Tạo niềm tin cho họ, đồng thời cũng giúp họ kiểm tra xem đây có phải là package họ thực sự cần. Ngoài ra có một trang demo cũng thể hiện sự đầu tư vào package của bạn, làm tăng thêm độ uy tín.

Tạo ra một trang demo cũng khá đơn giản, điều bạn cần là tìm một dịch vụ nào cho phép triển khai một ứng dụng vue.js lên đó. Thật may mắn tôi có biết đến vercel là hậu thân của (now.sh)[https://now.sh] có hỗ trợ điều đó.

Viết docs

Docs là rất quan trọng, phải có docs thì người dùng mới biết cách sử dụng package của bạn vì thế hãy đầu tư thời gian để hoàn thiện docs.

Docs cần rõ ràng & xúc tích, focus vào những tính năng chính mà package mang lại. Thông thường docs sẽ được trình bày theo "mô típ":

  • Giới thiệu ngắn gọn về package.
  • Get started: Giới thiệu cách cài đặt, cách sử dụng...
  • API: Phần này sẽ đi sâu vào phân tích những hàm, thuộc tính có trong package...
  • Dev: Hướng dẫn cách contribution.
  • License.
  • ...

Bạn hoàn toàn có thể viết docs trong file README.md hoặc sử dụng một số dịch vụ hỗ trợ trong việc trình bày như gitbook.

Publish package

Bước cuối cùng là tôi sẽ đẩy package lên npm thông qua cli của npm.

Nhưng trước khi đẩy các bạn cần lưu ý xem package của bạn có cần phải build ra không nhé. Thông thường build là bước để compiler code của bạn ra mã thuần Javascript.

Như trong package của tôi thì trước khi publish tôi cần chạy lệnh build:

$ npm run build

Sau đó là đẩy lên thôi:

$ npm login
$ npm publish

Tổng kết

Việc đẩy một package lên npm là không khó, tuy nhiên bạn cần phải chú ý trong việc lựa chọn nền tảng hoạt động của package cũng như các công cụ hỗ trợ việc build mã của bạn ra cho trình duyệt hay node.js hiểu để có thể sử dụng được.

Cao cấp
Hello

Tôi & khao khát "chơi chữ"

Bạn đã thử viết? Và rồi thất bại hoặc chưa ưng ý? Tại 2coffee.dev chúng tôi đã có quãng thời gian chật vật với công việc viết. Đừng nản chí, vì giờ đây chúng tôi đã có cách giúp bạn. Hãy bấm vào để trở thành hội viên ngay!

Bạn đã thử viết? Và rồi thất bại hoặc chưa ưng ý? Tại 2coffee.dev chúng tôi đã có quãng thời gian chật vật với công việc viết. Đừng nản chí, vì giờ đây chúng tôi đã có cách giúp bạn. Hãy bấm vào để trở thành hội viên ngay!

Xem tất cả

Đăng ký nhận thông báo bài viết mới

hoặc
* Bản tin tổng hợp được gửi mỗi 1-2 tuần, huỷ bất cứ lúc nào.

Bình luận (0)

Nội dung bình luận...