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

Tin ngắn hàng ngày dành cho bạn
  • swapy là một thư viện giúp bạn tạo ra thao tác kéo thả để hoán đổi vị trí của các thành phần một cách dễ dàng.

    Thư viện hỗ trợ rất nhiều nền tảng, rất thích hợp để xây dựng một cái gì đó mang tính cá nhân hoá như trang Dashboard của người dùng.

    » Xem thêm
  • Ui! Blog đang dính một lỗi bảo mật khá nghiêm trọng. Không biết có bạn nào phát hiện ra chưa. Dù chưa ảnh hưởng đến người dùng nhưng thông qua quá trình Eating your own dog food thì mới phát hiện ra á. Để sửa xong thì mình kể chi tiết.

    » Xem thêm
  • Ngủ dậy thấy bảng tin ngập tràn bài viết về việc Microsoft vừa viết lại trình biên dịch Typescript - tsc bằng Go, hiệu suất cho ra nhanh hơn gấp 10 lần so với cái hiện tại. Wow!

    Nhưng khi nhìn thấy tin này thì trong đầu nảy luôn ra câu hỏi "Tại sao không phải là Rust?". Bạn biết đấy, phong trào viết lại mọi thứ bằng Rust đang nóng hơn bao giờ hết, không ngoa khi nói rằng nó đang càn quét bảng xếp hạng của những công cụ kỳ cựu trước đó.

    Điều thú vị hơn nữa là viêc lựa chọn Go - mang lại hiệu suất tốt nhất cho đến thời điểm hiện tại - như họ nói. Thì rất nhiều người tỏ ra thất vọng vì tại sao không phải là C# 😆. Đấy khi bản nổi tiếng quá làm gì cũng bị xét nét từng tí một, nói chưa chắc ai cũng nghe 🥶

    Why Go? #411

    » 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...