اذهب إلى المحتوى
  • 0

NEXT JS - كيفية إزالة Query Params؟

عبد النور محمد

السؤال

كيف يمكنني إزالة أو تحديث معلمات الاستعلام بدون تحديث الصفحة في Next JS (React)؟

المستخدم موجود على

URL / about؟ login = success & something = yes


انقر فوق الزر وإزالة

login = success & something = yes

كيف يمكنني تحقيق ذلك؟

رابط هذا التعليق
شارك على الشبكات الإجتماعية

Recommended Posts

  • 0

هل تقصد أنك تريد إزالة ال Query Params عند الضغط على الزر ؟

إذا كان كذلك يمكنك استخدام الدالة router.replace كالتالي

const router = useRouter();

router.replace("/about", undefined, { shallow: true });

الرابط سوف يكون كالتالي فقط

/about

 لاحظ أن ال shallow: true تسمح لك تحديث الرابط بدون تنفيذ دوال ال data fetching 

يمكنك القراءة أكثر عن الموضوع من خلال موقع next تحت عنوان Shallow Routing

رابط هذا التعليق
شارك على الشبكات الإجتماعية

  • 0

السؤال غير واضح بشكل ما, هل تريد تغيير الurl ام تغيير المتغيرات في router.query ?  + ماذا تريد ان تحقق بالظبط حتى أستطيع مساعدتك

رابط هذا التعليق
شارك على الشبكات الإجتماعية

  • 0

يمكنك حل المشكلة بالشكل التالي:

push(`${asPath.split('?')[0]}?comp=${id}`);
// أو إذا كنت تريد دالة قابلة لإعادة الاستخدام
function delQuery(asPath) {
  return asPath.split('?')[0]
}
..
..
const {push, asPath} = useRouter()
push(`${delQuery(asPath)}?comp=${id}`);

كما يمكنك استخدام history.replaceState لكن قد :

if (typeof window !== "undefined") { 
  window.history.replaceState(null, '', '/about') 
}

 

تم التعديل في بواسطة Ali Haidar Ahmad
رابط هذا التعليق
شارك على الشبكات الإجتماعية

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...