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

كيفية الحصول على مسار عنوان URL في Next.js

Abdelrahman Mostafa10

السؤال

لدي صفحة تسجيل دخول (signin page) ومكوّن تخطيط (layout component) يحتوي على ترويسة (header)، أرغب في إخفاء الترويسة في صفحة تسجيل الدخول فقط، ولذلك أحتاج إلى طريقة للحصول على مسار عنوان URL الحالي، بناءًا على هذا المسار، سيتم تحديد ما إذا كان يجب إظهار الترويسة أم لا.

الكود لدي:

import * as constlocalStorage from '../helpers/localstorage';
import Router from 'next/router';

export default class MyApp extends App {
    componentDidMount() {
        if (constlocalStorage.getLocalStorage()) {
            Router.push({ pathname: '/app' });
        } else {
            Router.push({ pathname: '/signin' });
        }
    }

    render() {
        const { Component, pageProps } = this.props;
        return (
            // أحتاج إلى مسار عنوان URL هنا للتحقق من إمكانية إظهار الترويسة من عدمها
            <Layout>
                <Component {...pageProps} />
            </Layout>
        );
    }
}
رابط هذا التعليق
شارك على الشبكات الإجتماعية

Recommended Posts

  • 0

يمكنك الحصول على مسار العنوان في next js باستخدام المكون withRouter و الموجود في هذه المكتبة next/router

يمكنك استخدام المكون كالتالي


import * as constlocalStorage from '../helpers/localstorage';
import Router from 'next/router';
import { withRouter } from 'next/router';

export default class MyApp extends App {
    componentDidMount() {
        if (constlocalStorage.getLocalStorage()) {
            Router.push({ pathname: '/app' });
        } else {
            Router.push({ pathname: '/signin' });
        }
    }

    render() {
        const { pathname } = this.props.router;
        const { Component, pageProps } = this.props;
        return (
			 //pathname أصبح بإمكانك التحقق باستخدام  
           {pathname != '/signin' &&
            <Layout>
                <Component {...pageProps} />
            </Layout>
		   }
        );
    }
}

 

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

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

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

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

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

  • إعلانات

  • تابعنا على



×
×
  • أضف...