مهندس نرمافزار هستم و به عنوان Senior Software Engineer مشغول به کارم. به جاوااسکریپت، پایتون، دیتابیسها و طراحی و معماری نرمافزار علاقه زیادی دارم. وبلاگهام: yavarjs.ir و hamidreza.tech
استفاده از @ و /* در کامنتهای چندخطی جاوااسکریپت
نوشته رو در وبلاگ یاvar بخونید: yavarjs.ir/posts/special-symbols-multiline-comments
چجوری مشکل عدم امکان استفاده از علامتهای خاص و رزرو شده رو در کامنتهای چندخطی (multiline comments) و JSDoc حل کنیم؟
در حال اضافه کردن کامنت JSDoc به کدهام بودم که به یه مشکل اعصاب خوردنکن برخوردم. وقتی داشتم یک تیکه کد مثال رو توی کامنتم اضافه میکردم که داخلش از علامت /*
استفاده میشد، کل بلوک کامنتم خراب میشد. دلیلش هم اینه که این علامت در جاوااسکریپت به عنوان تگ پایان کامنتهای چندخطی استفاده میشه و وقتی داخل خود کامنت میخوای ازش استفاده کنی جاوااسکریپت فکر میکنه که داری بلوک کامنتت رو میبندی!
این مشکل توی تیکه کد پایین قابل مشاهدهاست:
/**
* Checks whether two permission strings are semantically equal or not.
*
* @example
* // returns true
* equals('a/b/c/d/allow', 'a/b/c/*/*/d/allow');
*
* @returns {boolean} True in case of equality and false otherwise.
*/
const equals = (first: string, second: string) => {
// function's logic
// ...
return true; // or false
}
این مشکل راه حل ساده و جالبی داره: باید یه کاراکتر جداکنندهی مخفی بین *
و /
قرار داده بشه! این کاراکتر یونیکد که اسمش هست Unicode invisible separator character باعث میشه که جاوااسکریپت علامت پایان کامنت رو تشخیص نده. این کاراکتر رو میتونید از اینجا کپی کنید.
دقیقا مشابه همین مشکل وقتی به وجود میاد که بخواید از علامت @
داخل کامنتهای JSDoc استفاده کنید. چون این علامت معنی خاصی برای JSDoc داره باعث خراب شدن داکیومنتی میشه که JSDoc تولید میکنه. به این تیکه کد یه نگاه بندازید:
/**
* A NestJS handler decorator that defines an access permission constraint and enforces it.
*
* @example
* ```ts
* // the request only needs to be authenticated and doesn't need any specific permissions
* @RequiresAccess()
* Class MyController {}
* ```
*/
export const RequiresAccess = Reflector.createDecorator<
PermissionPathGen | PermissionPathGen[]
>({
transform(value) {
return value == undefined ? MUST_BE_AUTHENTICATED : value
},
})
حل این مشکل هم مشابه قبلیه؛ کافیه یه کاراکتر جداکنندهی مخفی قبل از علامت @
قرار بدید.
منبع: Using @ and */ symbols inside JS multiline comments از وبلاگ Software Alchemist
مطلبی دیگر از این انتشارات
تنظیم Docker برای یه وباپ Node.js
مطلبی دیگر از این انتشارات
تاریخچه typeof null در جاوا اسکریپت
مطلبی دیگر از این انتشارات
استقرار سریع و ساده اپلیکیشن NestJS روی Vercel