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

استيراد مكون دينامكيا عبر dynamic في nextjs

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

السؤال

مرحبا أحاول استيراد مكون دينامكيا عبر متغير path أوفره بهذه الطريقة

import dynamic from 'next/dynamic'


const Test = () => {
  const router = useRouter();
  const { component } = router.query;
  const path = `../../components/${component.join('/')}`;


  const DynamicComponent = dynamic(() => import(path), {
    ssr: false,
    loading: () => <p>Loading...</p>,
  });



  return (
    <Fragment>
      <h1>Testing {path}</h1>
  
        <DynamicComponent />    
    </Fragment>
  );
};

لكن المكون لا يظهر ويبقى فقط loading ولا يتغير شئ

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

Recommended Posts

  • 0

يجب عليك وضع dynamic خارج المكون ، وسيعمل بشكلٍ جيد

const getDynamicComponent = (c) => dynamic(() => import(`../components/${c}`), {
  ssr: false,
  loading: () => <p>Loading...</p>,
});

const Test = () => {
  const router = useRouter();
  const { component } = router.query;
  
  const DynamicComponent = getDynamicComponent(component);

  return <DynamicComponent />
}

 

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

  • 0

يتم إستعمال كلمة dynamic في nextjs على الشكل الموضح في المثال أسفله:

في المثال التالي ، سيتم تحميل الوحدة ../components/hello ديناميكيًا بواسطة الصفحة

import dynamic from 'next/dynamic'

const DynamicComponent = dynamic(() => import('../components/hello'))

function Home() {
  return (
    <div>
      <Header />
      <DynamicComponent />
      <p>HOME PAGE is here!</p>
    </div>
  )
}

export default Home

سيكون DynamicComponent هو المكون الافتراضي الذي يتم إرجاعه بواسطة ../components/hello. إنه يعمل مثل مكون React العادي ، ويمكنك تمرير الدعائم إليه كما تفعل عادةً.

يمكنك تطبيق نفس الطريقة في الشيفرة الخاصة بك.

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

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

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

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

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   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.

  • إعلانات

  • تابعنا على



×
×
  • أضف...