جستجو برای "{{term}}"
جستجو برای "{{term}}" نتیجه ای نداشت.
پیشنهاد می شود:
  • از املای صحیح کلمات مطمئن شوید.
  • از کلمات کمتری استفاده کنید.
  • فقط کلمه کلیدی عبارت مورد نظر خود را جستجو کنید.
{{count()}} نتیجه پیدا شد. برای دیدن نتایج روی دکمه های زیر کلیک کنید!
نتیجه ای یافت نشد.
سایر نتیجه ها (دپارتمان ها، اخبار، مقالات، صفحات) را بررسی کنید.

{{item.title}}

{{item.caption}}
نتیجه ای یافت نشد.
سایر نتیجه ها (دوره ها، اخبار، مقالات، صفحات) را بررسی کنید.

{{item.title}}

{{item.caption}}
نتیجه ای یافت نشد.
سایر نتیجه ها (دوره ها، دپارتمان ها، مقالات، صفحات) را بررسی کنید.

{{item.title}}

{{item.caption}}
{{item.datetime}}
نتیجه ای یافت نشد.
سایر نتیجه ها (دوره ها، دپارتمان ها، اخبار، صفحات) را بررسی کنید.

{{item.title}}

{{item.caption}}
{{item.datetime}}
نتیجه ای یافت نشد.
سایر نتیجه ها (دوره ها، دپارتمان ها، اخبار، مقالات) را بررسی کنید.

{{item.title}}

{{item.caption}}
{{item.datetime}}
  • پنجشنبه ۶ آذر ۱۴۰۴
۷

آزمایشگاه‌های ری‌اکت (بخش دوم)

سفارشی‌سازی انیمیشن‌ها در ری‌اکت

انتقال‌های نمایشی ری‌اکت (React View Transitions) یک امکان آزمایشی جدید است که افزودن انیمیشن را به ترنزیشن‌های رابط کاربری برنامه آسان‌تر می‌کند.

چکیده

وقتی مدل شیءگرای سند یا DOM به واسطهٔ یک تریگر انیمیشن مانند startTransition، useDeferredValue یا تغییر محتوا توسط Suspense به‌روزرسانی می‌شود، ری‌اکت از روش اکتشاف اعلانی استفاده می‌کند تا به‌طور خودکار اجرای <ViewTransition> را تعیین کرده و انیمیشن را فعال کند. سپس مرورگر انیمیشنی را که در CSS تعریف شده اجرا می‌کند.

اگر با View Transition API در مرورگر آشنا هستید و می‌خواهید بدانید ری‌اکت چگونه آن را پشتیبانی می‌کند به مطلب مربوط به «نحوهٔ کار <ViewTransition> در اسناد» مراجعه کنید.

ReactJS یا ری‌اکت یکی از محبوب‌ترین فریم‌ورک‌های کتابخانهٔ جاوا اسکریپت برای ساخت رابط‌های کاربری پویا و جذاب است. با توجه به ویژگی‌های این فریم‌ورک، فرصت‌های شغلی زیادی برای استخدام متخصصان این حوزه وجود دارد. دپارتمان فناوری اطلاعات و ارتباطات مجتمع فنی تهران با برگزاری دوره ری اکت این امکان را فراهم کرده تا شما بتوانید تجربه‌‌ای خاص و کاربردی برای کاربران ایجاد کنید و عملکرد اپلیکیشن‌ها را بهبود بخشید. افرادی که قصد دارند در دوره آموزشreactjs  شرکت کنند باید  آموزش طراحی وب سایت را گذرانده باشند. در غیر این صورت درک مباحث دورهٔ ری‌اکت برای آنها دشوار خواهد بود.

به‌روزرسانی‌های جدید ری‌اکت

ری‌اکت که با نام‌های React.js و ReactJS نیز شناخته می‌شود یک کتابخانهٔ رایگان و متن باز است که از جاوا اسکریپت استفاده می‌کند و برای فرانت‌اند مورد استفاده قرار می‌گیرد. هدف ری‌اکت ساده‌تر و روان‌ترکردن ساخت رابط‌های کاربری است که مبتنی بر کامپوننت باشند. این کتابخانه را شرکت متا یا همان فیسبوک سابق ساخته است و توسعه‌دهندگان مستقل با آن همکاری و در نگهداری و پشتیبانی از آن کمک می‌کنند.

در این سری مطالب در مورد پروژه‌های فعال در بخش تحقیق و توسعهٔ ری‌اکت صحبت می‌کنیم. به دو ویژگی جدید ری‌اکت اشاره خواهیم کرد که اکنون آمادهٔ آزمایش هستند. همچنین به‌روزرسانی سایر حوزه‌هایی را که مشغول کار در آنها هستیم منتشر می‌کنیم. امروز ما مفتخریم که مستندات مربوط به دو امکان جدید ری‌اکت را آمادهٔ تست هستند منتشر کنیم و آنها عبارت‌اند از:

  • انتقال‌های نمایشی
  • اکتیویتی

انتقال‌های نمایشی ری‌اکت (React View Transitions) یک امکان آزمایشی جدید است که افزودن انیمیشن را به ترنزیشن‌های رابط کاربری برنامه آسان‌تر می‌کند. اکنون دو امکان انتقال‌های نمایشی و اکتیویتی برای آزمایش در react@experimental موجود هستند. این امکانات در محیط عملیاتی آزمایش شده‌اند و پایدار هستند، اما API نهایی ممکن است براساس بازخوردها تغییر کند. می‌توانید با ارتقای بستهٔ ری‌اکت به جدیدترین نسخهٔ آزمایشی این امکانات را امتحان کنید:

  • react@experimental
  • react-dom@experimental

در مطلب آزمایشگاه‌های ری‌اکت (بخش نخست) بخشی از به‌روزرسانی‌های انتقال نمایشی را توضیح دادیم و در این مطلب به ادامهٔ آن مبحث می‌پردازیم و با سفارشی‌سازی انیمیشن‌ها آغاز می‌کنیم.

سفارشی‌سازی انیمیشن‌ها در ری‌اکت

به‌طور پیش‌فرض <ViewTransition> شامل محوشدگی متقاطع پیش‌فرض در مرورگر است. برای سفارشی‌سازی انیمیشن‌ها می‌توانید پراپ‌ها را به کامپوننت <ViewTransition> ارائه دهید تا مشخص شود براساس نحوهٔ فعال‌شدن <ViewTransition> از کدام انیمیشن‌ها استفاده کند. برای نمونه می‌توانیم دستور انیمیشن محوشدن متقاطع پیش‌فرض را این‌گونه کندتر کنیم:

 

 

 

و محوشدگی آهسته را در CSS با استفاده از کلاس‌های انتقال‌نما تعریف کنید:

::view-transition-old(.slow-fade) {

    animation-duration: 500ms;

}

 

::view-transition-new(.slow-fade) {

    animation-duration: 500ms;

}

حال محوشدگی متقاطع کندتر می‌شود:

1 import { unstable_ViewTransition as ViewTransition } from "react";

2 import Details from "./Details";

3 import Home from "./Home";

4 import { useRouter } from "./router";

5

6 export default function App() {

7   const { url } = useRouter();

8

 9 // Define a default animation of .slow-fade.

 10 // See animations.css for the animation definiton.

11 return (

12   

13     {url === '/' ? :

}

 

14  

15  );

16 }

توجه داشته باشید که به دلیل محدودیت این مقاله صرفاً کدهای App.js در اینجا آمده‌اند و برای مشاهدهٔ سایر کدها ازجمله موارد زیر از طریق لینک پایین مقاله به خود آن مراجعه کنید.

Details.js, Home.js, Layout.js, Videos.js, router.js, animations.css

برای بررسی کامل‌تر سبک‌سازی در بنگرید به مطلب سبک‌سازی انتقال نما.

ترنزیشن عناصر مشترک در ری‌اکت

وقتی دو صفحه شامل یک عنصر یکسان باشند، اغلب لازم است آن را از یک صفحه به صفحهٔ دیگر با انیمیشن منتقل کنید. برای انجام این کار می‌توانید یک نام منحصربه‌فرد به <ViewTransition> اضافه کنید:

 

 

حال تصویر کوچک نشان‌دهندهٔ ویدیو بین دو صفحه متحرک‌سازی می‌شود:

1 import { useState, unstable_ViewTransition as ViewTransition } from "react"; import LikeButton from "./LikeButton"; import { useRouter } from "./router"; import { PauseIcon, PlayIcon } from "./Icons"; import { startTransition } from "react";

2

3 export function Thumbnail({ video, children }) {

4  // Add a name to animate with a shared element transition.

5  // This uses the default animation, no additional css needed.

6  return (

7   

8    

9        aria-hidden="true"

10        tabIndex={-1}

11        className={`thumbnail ${video.image}`}

 12     >

13        {children}

14     

15   

16  );

17 }

18

19 export function VideoControls() {

20  const [isPlaying, setIsPlaying] = useState(false);

21

22  return (

23   

24      className="controls"

25      onClick={() =>

26        startTransition(() => {

27          setIsPlaying((p) => !p);

28        })

29      }

30    >

31      {isPlaying ? : }

32   

33  );

34 }

35

36 export function Video({ video }) {

37  const { navigate } = useRouter();

38

39  return (

40   

 

41     

42        className="link"

43   onClick={(e) => {

44          e.preventDefault();

45          navigate(`/video/${video.id}`);

 46       }}

47      >

48       

49

50       

 

 51        

{video.title}

 

52         

{video.description}

 

53       

 

54     

 

55     

56   

57  );

58 }

به‌طور پیش‌فرض ری‌اکت نامی منحصر‌به‌فرد برای هر عنصری که در ترنزیشن فعال می‌شود اختصاص می‌دهد و این کار را به‌طور خودکار انجام می‌دهد. بنگرید به مطلب مربوط به نحوهٔ عملکرد . وقتی ری‌اکت ترنزیشنی را ببیند که در آن با یک اسم پاک‌شده است و سپس آن با همان اسم در اضافه شده است، عناصر مشترک را فعال خواهد کرد. برای اطلاعات بیشتر در این مورد بنگرید به اسناد مربوط به متحرک‌سازی عنصر مشترک.

انیمیشن‌سازی در ری‌اکت براساس دلیل

برخی اوقات شما می‌خواهید عناصر براساس چگونگی فعال‌شدن آنها به‌شیوه‌های مختلف متحرک‌سازی شوند. ما در مثال خودمان یک API جدید به نام addTransitionType اضافه کرده‌ایم تا دلیل ترنزیشن را مشخص کنیم.

function navigate(url) {

  startTransition(() => {

    // Transition type for the cause "nav forward"

    addTransitionType('nav-forward');

    go(url);

  });

}

function navigateBack(url) {

  startTransition(() => {

    // Transition type for the cause "nav backward"

    addTransitionType('nav-back');

    go(url);

  });

}

شما می‌توانید براساس نوع ترنزیشن، انیمیشن‌های سفارشی را از طریق پراپ‌ها به بدهید. در اینجا ما ترنزیشن عنصر مشترک را به سربرگ همان صفحهٔ نمایش ویدیوها در مثال‌مان اضافه کرده‌ایم:

  name="nav"

  share={{

    'nav-forward': 'slide-forward',

    'nav-back': 'slide-back',

  }}>

  {heading}

 

در اینجا ما یک ویژگی اشتراک‌گذاری پراپ برای تعریف نحوهٔ متحرک‌سازی براساس نوع انتقال یا ترنزیشن ارسال می‌کنیم. وقتی ترنزیشن اشتراک‌گذاری از nav-forward فعال می‌شود، کلاس انتقال نمای slide-forward اعمال می‌شود. وقتی از nav-back فعال می‌شود، انیمیشن slide-back فعال می‌شود. این انیمیشن‌ها را در CSS این‌گونه تعریف می‌کنیم:

::view-transition-old(.slide-forward) {

    /* when sliding forward, the "old" page should slide out to left. */

    animation: ...

}

 

::view-transition-new(.slide-forward) {

    /* when sliding forward, the "new" page should slide in from right. */

    animation: ...

}

 

::view-transition-old(.slide-back) {

    /* when sliding back, the "old" page should slide out to right. */

    animation: ...

}

 

::view-transition-new(.slide-back) {

    /* when sliding back, the "new" page should slide in from left. */

    animation: ...

}

حال ما می‌توانیم سربرگ را با تصویر بندانگشتی براساس نوع ناوبری متحرک‌سازی کنیم:

1 import {unstable_ViewTransition as ViewTransition} from 'react'; import { useIsNavPending } from "./router";

2

3 export default function Page({ heading, children }) {

4  const isPending = useIsNavPending();

5  return (

6   

 

7     

 

8       

 

9          {/* Custom classes based on transition type. */}

10         

11            name="nav"

12            share={{

13              'nav-forward': 'slide-forward',

14              'nav-back': 'slide-back',

15            }}>

16            {heading}

17         

18          {isPending && }

19       

 

20     

 

21      {/* Opt-out of ViewTransition for the content. */}

22      {/* Content can define it's own ViewTransition. */}

23     

24       

 

25        

{children}

 

26       

 

27     

  28 

 

29  );

30 }

متحرک‌سازی مرزهای Suspense در ری‌اکت

Suspense نیز ترنزیشن‌های نما را فعال می‌کند. برای متحرک‌سازی محتواهای جایگزین می‌توانیم Suspense را با بسته‌بندی کنیم.

 

  }>

   

 

 

با افزودن آن محتواهای جایگزین به‌طور متقاطع در محتوای قبلی محو می‌شود. روی یکی از ویدیوها کلیک کنید و اطلاعات ویدیو را به‌صورت متحرک در زیر مشاهده کنید.

1 import { use, Suspense, unstable_ViewTransition as ViewTransition } from "react"; import { fetchVideo, fetchVideoDetails } from "./data"; import { Thumbnail, VideoControls } from "./Videos"; import { useRouter } from "./router"; import Layout from "./Layout"; import { ChevronLeft } from "./Icons";

2

3 function VideoDetails({ id }) {

4  // Cross-fade the fallback to content.

5  return (

6    

 7     }>

 8        

 9    

 10  

 11 );

12 }

13

14 function VideoInfoFallback() {

15  return (

16   

 

17     

 

 

18     

 

 

19   

 

20  );

21 }

22

23 export default function Details() {

24 const { url, navigateBack } = useRouter();

25  const videoId = url.split("/").pop();

26  const video = use(fetchVideo(videoId));

27

28  return (

29   

30      heading={

31       

 32         className="fit back"

33          onClick={() => {

34            navigateBack("/");

35          }}

36        >

37          Back

38        

39      }

40    >

41     

 

42       

43         

44       

45       

46     

 

47   

48  );

49 }

50

51 function VideoInfo({ id }) {

52 const details = use(fetchVideoDetails(id));

53  return (

54   

 

 55    

{details.title}

 

 56    

{details.description}

 

 57  

 

 58 );

59 }

همچنین می‌توان با استفاده از exit در fallback و enter در محتوا انیمیشن‌های سفارشی را وارد کنیم.

  fallback={

   

     

   

  }

 

   

 

 

به شیوهٔ زیر با css می‌توانیم slide-down و slide-up را تعریف کنیم.

::view-transition-old(.slide-down) {

  /* Slide the fallback down */

  animation: ...;

}

 

::view-transition-new(.slide-up) {

  /* Slide the content up */

  animation: ...;

}

حال محتوای Suspense در انیمیشنی با حالت کشویی جایگزین fallback می‌شود:

1 import { use, Suspense, unstable_ViewTransition as ViewTransition } from "react"; import { fetchVideo, fetchVideoDetails } from "./data"; import { Thumbnail, VideoControls } from "./Videos"; import { useRouter } from "./router"; import Layout from "./Layout"; import { ChevronLeft } from "./Icons";

2

3 function VideoDetails({ id }) {

4  return (

5   

6      fallback={

 7       // Animate the fallback down.

8       

 9        

 10      

11      }

12    >

13      {/* Animate the content up */}

14     

15       

16     

17   

18  );

19 }

20

21 function VideoInfoFallback() {

22  return (

23    <>

24     

 

 

25     

 

 

26   

27  );

28 }

29

30 export default function Details() {

31  const { url, navigateBack } = useRouter();

32  const videoId = url.split("/").pop();

33  const video = use(fetchVideo(videoId));

34

35  return (

36   

37      heading={

38       

39          className="fit back"

40          onClick={() => {

41            navigateBack("/");

42          }}

 43       >

 44         Back

 45      

 46     }

47    >

48     

 

 49      

  50       

 51      

 52      

53     

 

54   

55  );

56 }

57

58 function VideoInfo({ id }) {

59  const details = use(fetchVideoDetails(id));

60  return (

 61   <>

62     

{details.title}

 

63     

{details.description}

 

64   

65  );

66 }

متحرک‌سازی لیست‌ها در ری‌اکت

می‌توانید با استفاده از لیست‌ آیتم‌ها را که وقتی دوباره سفارش داده می‌شوند متحرک‌سازی کنید و به شکل فهرستی قابل جستجو از آیتم‌ها درآورید.

 

 

  {filteredVideos.map((video) => (

   

     

   

  ))}

 

 

ما می‌توانیم برای فعال‌سازی ViewTransition از useDeferredValue استفاده کنیم.

const [searchText, setSearchText] = useState(‘’);

const deferredSearchText = useDeferredValue(searchText);

const filteredVideos = filterVideos(videos, deferredSearchText);

حال آیتم‌ها همزمان با تایپ شما در نوار جستجو متحرک می‌شوند:

1 import { useId, useState, use, useDeferredValue, unstable_ViewTransition as ViewTransition } from "react";import { Video } from "./Videos";import Layout from "./Layout";import { fetchVideos } from "./data";import { IconSearch } from "./Icons";

2

3 function SearchList({searchText, videos}) {

4  // Activate with useDeferredValue ("when")

5  const deferredSearchText = useDeferredValue(searchText);

6  const filteredVideos = filterVideos(videos, deferredSearchText);

7  return (

8   

 

9     

 

 10       {filteredVideos.map((video) => (

11          // Animate each item in list ("what")

12         

 13          

14         

15        ))}

16     

 

17      {filteredVideos.length === 0 && (

18       

No results

 

19      )}

20   

 

21  );

22 }

23

24 export default function Home() {

25  const videos = use(fetchVideos());

26  const count = videos.length;

27  const [searchText, setSearchText] = useState('');

28 

29  return (

30    {count} Videos}>

 31    

32     

33   

34  );

35 }

36

37 function SearchInput({ value, onChange }) {

38  const id = useId();

39  return (

40   

e.preventDefault()}>

 

 41    

42        Search

43     

44     

 

 45      

 

46         

47       

 

48       

49          type="text"

50          id={id}

51          placeholder="Search"

52          value={value}

53          onChange={(e) => onChange(e.target.value)}

54        />

55     

 

56   

 

57  );

58 }

59

60 function filterVideos(videos, query) {

61  const keywords = query

62    .toLowerCase()

63    .split(" ")

64    .filter((s) => s !== "");

65  if (keywords.length === 0) {

66    return videos;

67  }

68  return videos.filter((video) => {

69    const words = (video.title + " " + video.description)

70      .toLowerCase()

71      .split(" ");

72    return keywords.every((kw) => words.some((w) => w.includes(kw)));

73  });

74 }

نتیجهٔ نهایی اینکه با اضافه‌کردن چند کامپوننت <ViewTransition> و چند خط CSS توانستیم تمام انیمینش‌هار بالا را به نتیجهٔ نهایی در ری‌اکت اضافه کنیم. به همین دلیل ما از وضعیت فعلی View Transitions بسیار راضی هستیم و فکر می‌کنیم برنامه‌هایی که با آن می‌سازید با این به‌روزرسانی‌ها ارتقا می‌یابند. این به‌روزرسانی‌ها امروز در کانال اسناد منتشرشدهٔ ری‌اکت آماده هستند تا آنها را امتحان کنید.

در ادامه دستور محوشدن آهسته را حذف می‌کنیم و به نتیجهٔ نهایی نگاهی می‌اندازیم.

1 import {unstable_ViewTransition as ViewTransition} from 'react'; import Details from './Details'; import Home from './Home'; import {useRouter} from './router';

2

3 export default function App() {

 4 const {url} = useRouter();

5

6  // Animate with a cross fade between pages.

7  return (

8   

9      {url === '/' ? :

}

 

10   

11  );

12 }

برای آشنایی بیشتر با نحوهٔ‌ کار آنها به مطلب مربوط به چگونگی عملکرد   مراجعه کنید. برای اطلاعات بیشتر در مورد نحوهٔ ساخت View Transitions بنگرید به لینک‌های زیر

#31975, #32105, #32041, #32734, #32797 #31999, #32031, #32050, #32820, #32029, #32028, and #32038 by @sebmarkbage

توجه داشته باشید که به دلیل محدودیت این مقاله صرفاً کدهای App.js در اینجا آمده‌اند و برای مشاهدهٔ سایر کدها ازجمله موارد زیر از طریق لینک پایین مقاله به خود آن مراجعه کنید.

Details.js, Home.js, Layout.js, Videos.js, router.js, animations.css

جمع‌بندی

در ری‌اکت انتقال‌های نمایشی یا View Transitions جایگزین انیمیشن‌های CSS و JS نمی‌شوند. انتقال‌های نمایشی برای ترنزیشن‌های رابط کاربری مانند ناوبری، گسترش، بازکردن یا مرتب‌سازی مجدد مورد استفاده قرار می‌گیرند و نمی‌توانند جایگزین همهٔ‌ انیمیشن‌ها برنامهٔ شما شوند. اکنون دو امکان انتقال‌های نمایشی و اکتیویتی برای آزمایش در react@experimental موجود هستند. این امکانات در محیط عملیاتی آزمایش شده‌اند و پایدار هستند، اما API نهایی ممکن است براساس بازخوردها تغییر کند. می‌توانید با ارتقای بستهٔ ری‌اکت به جدیدترین نسخهٔ آزمایشی این امکانات را امتحان کنید.

در مطلب آزمایشگاه‌های ری‌اکت (بخش نخست) بخشی از به‌روزرسانی‌های انتقال نمایشی را توضیح دادیم و در این مطلب به ادامهٔ آن مبحث پرداختیم و با سفارشی‌سازی انیمیشن‌ها آغاز کردیم. در مطلب آزمایشگاه‌های ری‌اکت (بخش سوم) به امکان جدید دیگر ری‌اکت یعنی اکتیویتی خواهیم پرداخت.

ReactJS یا ری‌اکت یکی از محبوب‌ترین فریم‌ورک‌های کتابخانهٔ جاوا اسکریپت برای ساخت رابط‌های کاربری پویا و جذاب است. با توجه به ویژگی‌های این فریم‌ورک، فرصت‌های شغلی زیادی برای استخدام متخصصان این حوزه وجود دارد. دپارتمان فناوری اطلاعات و ارتباطات مجتمع فنی تهران با برگزاری دوره ری اکت این امکان را فراهم کرده تا شما بتوانید تجربه‌‌ای خاص و کاربردی برای کاربران ایجاد کنید و عملکرد اپلیکیشن‌ها را بهبود بخشید. افرادی که قصد دارند در دوره آموزشreactjs  شرکت کنند باید  آموزش طراحی وب سایت را گذرانده باشند. در غیر این صورت درک مباحث دورهٔ ری‌اکت برای آنها دشوار خواهد بود.

در دنیای کسب‌وکار امروز، تحصیلات دانشگاهی برای حفظ ارزش شما به‌عنوان نیروی کار بااستعداد و کارآمد کافی نیستند. برای‌ اینکه مزیت رقابتی شخصی خود را حفظ کنید، باید بر آموزش مستمر و مادام‌العمر خود سرمایه‌گذاری کنید. خانواده بزرگ مجتمع فنی تهران هرساله به هزاران نفر کمک می‌کند تا در مسیر شغلی خود پیشرفت کنند.

اگر شاغل هستید و وقت ندارید در دوره‌های آموزشی حضوری شرکت کنید، مجتمع فنی تهران گزینه‌هایی عالی برای آموزش مجازی، آنلاین، آفلاین و ترکیبی ارائه می‌دهد. با شرکت در دوره‌های کوتاه‌مدت مجتمع فنی تهران و دریافت مدارک معتبر و بین‌المللی می‌توانید با اعتماد به نفس مسیر ترقی را طی کنید و در سازمان خود به مهره‌ای ارزشمند تبدیل شود.

نویسنده: ریکی هانلون

مترجم: بهناز دهکردی

منبع: React.dev

پرسش‌های متداول

امکانات جدید ری‌اکت در ترنزیشن کدام‌اند؟

  • <ViewTransition> کامپوننتی است که به شما امکان می‌دهد یک انیمیشن را برای ترنزیشن یا انتقال فعال کنید.
  • addTransitionType: تابعی است که به شما امکان می‌دهد علت ترنزیشن را مشخص کنید.
  • <Activity> کامپوننتی است که به شما امکان می‌دهد بخش‌هایی از رابط کاربری را پنهان یا آشکار کنید.

ری‌اکت چیست؟

ری‌اکت گه با نام‌های React.js و ReactJS نیز شناخته می‌شود یک کتابخانهٔ رایگان و متن باز است که از جاوا اسکریپت استفاده می‌کند و برای فرانت‌اند مورد استفاده قرار می‌گیرد. هدف ری‌اکت ساده‌تر و ران‌ترکردن ساخت رابط‌های کاربری است که مبتنی بر کامپوننت باشند. این کتابخانه را شرکت متا یا همان فیسبوک سابق ساخته است و توسعه‌دهندگان مستقل با آن همکاری و در نگهداری و پشتیبانی از آن کمک می‌کنند.

پربازدیدترین مقالات