」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 開發人員的綜合 React.js 備忘單

開發人員的綜合 React.js 備忘單

發佈於2024-07-30
瀏覽:785

Comprehensive React.js Cheatsheet for Developers

React.js has become a cornerstone in modern web development for building dynamic and high-performance web applications. This comprehensive cheatsheet will cover everything you need to know to master React.js, including practical examples, code snippets, and detailed explanations of all features. The goal is to provide an in-depth guide that you can refer to anytime.


1. Introduction to React

React.js, often simply referred to as React, is an open-source JavaScript library used for building user interfaces, particularly for single-page applications where you need a fast and interactive user experience. Developed by Facebook, React allows developers to create large web applications that can update and render efficiently in response to data changes.

React's core concept is the component, which is a self-contained module that renders some output. Components can be nested, managed, and handled independently, making the development process efficient and maintainable.

2. Getting Started with React

Setting Up the Environment

Before starting with React, you need to set up the development environment. Here's how:

  1. Install Node.js and npm: React relies on Node.js and npm (Node Package Manager) for managing dependencies.
  • Download and install Node.js from the official website.

  • Verify the installation by running:

     node -v
     npm -v
    
  1. Install Create React App: Create React App is a comfortable environment for learning React and a great way to start a new single-page application in React.

    npm install -g create-react-app
    

Creating a New React App

Once the environment is set up, you can create a new React application.

  1. Create a New Project:

    npx create-react-app my-app
    cd my-app
    npm start
    

This command creates a new directory with the specified name (my-app), sets up a new React project, and starts the development server. You can open your browser and go to http://localhost:3000 to see your new React application.

3. React Components

Components are the building blocks of any React application. They let you split the UI into independent, reusable pieces.

Functional Components

Functional components are JavaScript functions that accept props as an argument and return React elements. They are simpler and easier to write than class components.

import React from 'react';

const Welcome = ({ name }) => {
  return 

Welcome, {name}!

; }; export default Welcome;

Class Components

Class components are ES6 classes that extend React.Component and have a render method that returns a React element.

import React, { Component } from 'react';

class Welcome extends Component {
  render() {
    return 

Welcome, {this.props.name}!

; } } export default Welcome;

Differences Between Functional and Class Components

  • State Management: Functional components use hooks (useState, useEffect, etc.) for state management, while class components use this.state and lifecycle methods.

  • Lifecycle Methods: Class components have lifecycle methods like componentDidMount, componentDidUpdate, and componentWillUnmount. Functional components use the useEffect hook to handle side effects.

  • Simplicity: Functional components are simpler and less verbose, making them easier to read and maintain.

4. JSX

JSX is a syntax extension that allows you to write HTML directly within JavaScript. It produces React "elements".

JSX Syntax

JSX looks like HTML but is transformed into JavaScript.

const element = 

Hello, world!

;

Embedding Expressions

You can embed any JavaScript expression in JSX by wrapping it in curly braces.

const name = 'John';
const element = 

Hello, {name}!

;

JSX Attributes

JSX allows you to use attributes with a syntax similar to HTML.

const element = {user.name};

5. State and Props

Understanding State

State is a built-in object that stores property values that belong to the component. When the state object changes, the component re-renders.

Managing State with useState Hook

The useState hook is used to add state to functional components.

import React, { useState } from 'react';

const Counter = () => {
  const [count, setCount] = useState(0);

  return (
    

You clicked {count} times

); }; export default Counter;

Understanding Props

Props are arguments passed into React components. Props are passed to components via HTML attributes.

Passing Props

Props are read-only and immutable.

const Greeting = (props) => {
  return 

Hello, {props.name}!

; }; const App = () => { return ; };

Prop Types and Default Props

PropTypes allow you to define the type of props a component should receive. Default props can be defined to ensure that a prop will have a value if it was not specified.

import React from 'react';
import PropTypes from 'prop-types';

const Greeting = ({ name }) => {
  return 

Hello, {name}!

; }; Greeting.propTypes = { name: PropTypes.string.isRequired, }; Greeting.defaultProps = { name: 'Guest', }; export default Greeting;

6. Component Lifecycle

Lifecycle Methods in Class Components

Lifecycle methods are special methods in class components that run at specific points in a component's life.

  • componentDidMount: Executed after the component is rendered.

  • componentDidUpdate: Executed after the component's updates are flushed to the DOM.

  • componentWillUnmount: Executed before the component is removed from the DOM.

class MyComponent extends React.Component {
  componentDidMount() {
    // Runs after component is mounted
  }

  componentDidUpdate(prevProps, prevState) {
    // Runs after component updates
  }

  componentWillUnmount() {
    // Runs before component is unmounted
  }

  render() {
    return 
My Component
; } }

Using useEffect Hook

The useEffect hook combines the functionalities of componentDidMount, componentDidUpdate, and componentWillUnmount.

import React, { useState, useEffect } from 'react';

const MyComponent = () => {
  const [count, setCount] = useState(0);

  useEffect(() => {
    // Runs on mount and update
    document.title = `You clicked ${count} times`;

    // Cleanup function (runs on unmount)
    return () => {
      console.log('Cleanup');
    };
  }, [count]); // Dependency array

  return (
    

You clicked {count} times

); }; export default MyComponent;

7. Handling Events

Event Handling in React

React events are named using camelCase, rather than lowercase. With JSX, you pass a function as the event handler, rather than a string.

const handleClick = () => {
  console.log('Button clicked');
};

const MyComponent = () => {
  return ;
};

Synthetic Events

React's event system is known as Synthetic Events. It is a cross-browser wrapper around the browser's native event system.

Handling Forms

Handling forms in React involves controlling the input elements and managing the state.

import React, { useState } from 'react';

const MyForm = () => {
  const [value, setValue] = useState('');

  const handleChange = (event) => {
    setValue(event.target.value);
  };

  const handleSubmit = (event) => {
    event.preventDefault();
    alert('A name was submitted: '   value);
  };

  return (
    
); }; export default MyForm;

Event Handler Best Practices

  • Avoid inline event handlers: Define event handlers outside of the JSX for better readability and performance.

  • Use Arrow Functions: Use arrow functions to avoid issues with this binding.

  • Debounce Expensive Operations: Debounce expensive operations like API calls to avoid performance issues.

8. Conditional Rendering

if-else Statements

You can use JavaScript if-else statements inside the render method.

const MyComponent = ({ isLoggedIn }) => {
  if (isLoggedIn) {
    return 

Welcome back!

; } else { return

Please sign in.

; } };

Ternary Operators

Ternary operators are a concise way to perform conditional rendering.

const MyComponent = ({ isLoggedIn }) => {
  return (
    
{isLoggedIn ?

Welcome back!

:

Please sign in.

}
); };

Logical && Operator

You can use the logical && operator to include elements conditionally.

const MyComponent = ({ isLoggedIn }) => {
  return (
    
{isLoggedIn &&

Welcome back!

}
); };

Inline If with Logical && Operator

Inline if with logical && operator allows you to conditionally include an element in the output.

const Mailbox = ({ unreadMessages }) => {
  return (
    

Hello!

{unreadMessages.length > 0 &&

You have {unreadMessages.length} unread messages.

}
); };

9. Lists and Keys

Rendering Lists

You can build collections of elements and include them in JSX using curly braces {}.

const numbers = [1, 2, 3, 4, 5];
const listItems = numbers.map((number) =>
  
  • {number}
  • ); const NumberList = () => { return (
      {listItems}
    ); };

    Using Keys

    Keys help React identify which items have changed, are added, or are removed. Keys should be given to the elements inside the array to give the elements a stable identity.

    const NumberList = (props) => {
      const numbers = props.numbers;
      const listItems = numbers.map((number) =>
        
  • {number}
  • ); return (
      {listItems}
    ); };

    Keys Must Only Be Unique Among Siblings

    Keys used within arrays should be unique among their siblings.

    function Blog(props) {
      const sidebar = (
        
      {props.posts.map((post) =>
    • {post.title}
    • )}
    ); const content = props.posts.map((post) =>

    {post.title}

    {post.content}

    ); return (
    {sidebar}
    {content}
    ); }

    10. Forms and Controlled Components

    Handling Form Data

    Handling form data in React involves managing the state of the form fields.

    import React, { useState } from 'react';
    
    const MyForm = () => {
      const [value, setValue] = useState('');
    
      const handleChange = (event) => {
        setValue(event.target.value);
      };
    
      const handleSubmit = (event) => {
        event.preventDefault();
        alert('A name was submitted: '   value);
      };
    
      return (
        
    ); }; export default MyForm;

    Controlled vs Uncontrolled Components

    Controlled components are those that are controlled by React state. Uncontrolled components are those that maintain their own internal state.

    class NameForm extends React.Component {
      constructor(props) {
        super(props);
        this.state = { value: '' };
    
        this.handleChange = this.handleChange.bind(this);
        this.handleSubmit = this.handleSubmit.bind(this);
      }
    
      handleChange(event) {
        this.setState({ value: event.target.value });
      }
    
      handleSubmit(event) {
        alert('A name was submitted: '   this.state.value);
        event.preventDefault();
      }
    
      render() {
        return (
          
    ); } }

    Using Refs for Uncontrolled Components

    Refs provide a way to access DOM nodes or React elements created in the render method.

    class NameForm extends React.Component {
      constructor(props) {
        super(props);
        this.input = React.createRef();
        this.handleSubmit = this.handleSubmit.bind(this);
      }
    
      handleSubmit(event) {
        alert('A name was submitted: '   this.input.current.value);
        event.preventDefault();
      }
    
      render() {
        return (
          
    ); } }

    Form Validation

    Form validation ensures that user inputs are valid.

    const MyForm = () => {
      const [name, setName] = useState('');
      const [email, setEmail] = useState('');
      const [error, setError] = useState('');
    
      const handleSubmit = (event) => {
        event.preventDefault();
        if (!name || !email) {
          setError('Name and Email are required');
        } else {
          setError('');
          // Submit form
        }
      };
    
      return (
        
    {error &&

    {error}

    }
    ); }; export default MyForm;

    11. React Router

    React Router is a library for routing in React applications. It allows you to handle navigation and rendering of different components based on the URL.

    Setting Up React Router

    1. Install React Router:

      npm install react-router-dom
      
    2. Set Up Routes:

      import React from 'react';
      import { BrowserRouter as Router, Route, Switch } from 'react-router-dom';
      
      const Home = () => 

      Home

      ; const About = () =>

      About

      ; const App = () => { return ( ); }; export default App;

    Route Parameters

    You can use route parameters to capture values from the URL.

    import React from 'react';
    import { BrowserRouter as Router, Route,
    
     Switch, useParams } from 'react-router-dom';
    
    const User = () => {
      const { id } = useParams();
      return 

    User ID: {id}

    ; }; const App = () => { return ( ); }; export default App;

    Nested Routes

    Nested routes allow you to render sub-components within a parent component.

    import React from 'react';
    import { BrowserRouter as Router, Route, Switch, Link, useRouteMatch } from 'react-router-dom';
    
    const Topic = ({ match }) => 

    Requested Topic ID: {match.params.topicId}

    ; const Topics = ({ match }) => { let { path, url } = useRouteMatch(); return (

    Topics

    • Components
    • Props v. State

    Please select a topic.

    ); }; const App = () => { return (
    • Home
    • Topics

    ); }; export default App;

    Redirects and Navigation

    You can use the Redirect component to redirect to a different route programmatically.

    import React from 'react';
    import { BrowserRouter as Router, Route, Switch, Redirect } from 'react-router-dom';
    
    const Home = () => 

    Home

    ; const About = () =>

    About

    ; const App = () => { return ( ); }; export default App;

    12. Context API

    The Context API provides a way to pass data through the component tree without having to pass props down manually at every level.

    Creating Context

    To create a context, use React.createContext.

    const MyContext = React.createContext();
    

    Consuming Context

    To consume a context value, use the useContext hook in functional components or Context.Consumer in class components.

    const MyComponent = () => {
      const value = useContext(MyContext);
      return 
    {value}
    ; };

    Context with Functional Components

    const MyComponent = () => {
      return (
        
          
        
      );
    };
    
    const AnotherComponent = () => {
      const value = useContext(MyContext);
      return 
    {value}
    ; };

    Updating Context

    To update context, create a provider component with state.

    const MyProvider = ({ children }) => {
      const [value, setValue] = useState('Hello');
      return (
        
          {children}
        
      );
    };
    
    const MyComponent = () => {
      const { value, setValue } = useContext(MyContext);
      return (
        
    {value}
    ); };

    Context Best Practices

    • Avoid overusing context: Use context sparingly and only for global data.

    • Use multiple contexts: Separate concerns by using multiple contexts.

    • Memoize context values: Use useMemo to avoid unnecessary re-renders.

    13. Hooks

    Hooks are functions that let you use state and other React features in functional components.

    Basic Hooks (useState, useEffect)

    • useState: Adds state to functional components.

    • useEffect: Performs side effects in functional components.

    Additional Hooks (useContext, useReducer)

    • useContext: Accesses context values.

    • useReducer: Manages complex state logic.

    const initialState = { count: 0 };
    
    function reducer(state, action) {
      switch (action.type) {
        case 'increment':
          return { count: state.count   1 };
        case 'decrement':
          return { count: state.count - 1 };
        default:
          throw new Error();
      }
    }
    
    function Counter() {
      const [state, dispatch] = useReducer(reducer, initialState);
      return (
        
    Count: {state.count}
    ); }

    Custom Hooks

    Custom hooks are functions that encapsulate logic and can be reused across components.

    const useFetch = (url) => {
      const [data, setData] = useState(null);
    
      useEffect(() => {
        fetch(url)
          .then((response) => response.json())
          .then((data) => setData(data));
      }, [url]);
    
      return data;
    };
    
    const MyComponent = () => {
      const data = useFetch('https://api.example.com/data');
      return 
    {data ? JSON.stringify(data) : 'Loading...'}
    ; };

    Rules of Hooks

    • Call hooks at the top level: Do not call hooks inside loops, conditions, or nested functions.

    • Only call hooks from React functions: Call hooks from functional components or custom hooks.

    14. Higher-Order Components (HOC)

    Higher-Order Components (HOC) are functions that take a component and return a new component.

    Understanding HOCs

    HOCs are used to add additional functionality to components.

    const withLogging = (WrappedComponent) => {
      return (props) => {
        console.log('Rendering', WrappedComponent.name);
        return ;
      };
    };
    

    Creating HOCs

    const EnhancedComponent = withLogging(MyComponent);
    

    Using HOCs

    const MyComponent = (props) => {
      return 
    My Component
    ; }; const EnhancedComponent = withLogging(MyComponent);

    HOC Best Practices

    • Do not mutate the original component: Return a new component.

    • Use display names for debugging: Set displayName on the HOC for better debugging.

    15. Error Boundaries

    Error boundaries are React components that catch JavaScript errors anywhere in their child component tree, log those errors, and display a fallback UI.

    Implementing Error Boundaries

    Error boundaries catch errors during rendering, in lifecycle methods, and in constructors of the whole tree below them.

    class ErrorBoundary extends React.Component {
      constructor(props) {
        super(props);
        this.state = { hasError: false };
      }
    
      static getDerivedStateFromError(error) {
        return { hasError: true };
      }
    
      componentDidCatch(error, errorInfo) {
        // You can also log the error to an error reporting service
        console.log(error, errorInfo);
      }
    
      render() {
        if (this.state.hasError) {
          return 

    Something went wrong.

    ; } return this.props.children; } }

    Catching Errors

    Error boundaries catch errors in the render method and in lifecycle methods.

    const MyComponent = () => {
      throw new Error('An error occurred');
      return 
    My Component
    ; }; const App = () => { return ( ); };

    Error Boundaries Best Practices

    • Use error boundaries to catch errors in components: Use error boundaries to catch and display errors in UI components.

    • Log errors for debugging: Log errors to external services for debugging.

    16. React Performance Optimization

    Memoization

    Memoization helps to avoid re-rendering components unnecessarily.

    import React, { memo } from 'react';
    
    const MyComponent = memo(({ value }) => {
      return 
    {value}
    ; });

    Code Splitting

    Code splitting helps to load only the necessary code and improve performance.

    import React, { Suspense, lazy } from 'react';
    
    const OtherComponent = lazy(() => import('./OtherComponent'));
    
    const MyComponent = () => {
      return (
        Loading...}>
          
        
      );
    };
    

    Lazy Loading

    Lazy loading helps to load components only when they are needed.

    import React, { Suspense, lazy } from 'react';
    
    const Other
    
    Component = lazy(() => import('./OtherComponent'));
    
    const MyComponent = () => {
      return (
        Loading...}>
          
        
      );
    };
    

    useMemo and useCallback

    • useMemo: Memoizes expensive calculations.

    • useCallback: Memoizes functions.

    const MyComponent = ({ value }) => {
      const memoizedValue = useMemo(() => {
        return computeExpensiveValue(value);
      }, [value]);
    
      const memoizedCallback = useCallback(() => {
        doSomething(value);
      }, [value]);
    
      return (
        
    {memoizedValue}
    ); };

    React Developer Tools

    Use React Developer Tools to identify performance bottlenecks.

    17. Testing in React

    Jest and React Testing Library

    Jest and React Testing Library are popular tools for testing React components.

    Writing Tests

    • Snapshot Testing: Capture the rendered component and compare it with a saved snapshot.

    • Unit Testing: Test individual components and functions.

    • Integration Testing: Test the integration between components and services.

    import { render, screen } from '@testing-library/react';
    import MyComponent from './MyComponent';
    
    test('renders MyComponent', () => {
      render();
      const element = screen.getByText(/My Component/i);
      expect(element).toBeInTheDocument();
    });
    

    18. React Best Practices

    Component Structure

    • Organize components by feature: Group related components together.

    • Use descriptive names: Use clear and descriptive names for components and props.

    • Keep components small: Break down large components into smaller, reusable components.

    State Management

    • Lift state up: Lift state to the nearest common ancestor.

    • Use Context for global state: Use Context API for global state management.

    Styling

    • Use CSS Modules: Use CSS modules for scoped and modular styles.

    • Use styled-components: Use styled-components for dynamic styling.

    Performance

    • Avoid unnecessary re-renders: Use memoization and React's built-in performance optimization tools.

    • Use Code Splitting: Split your code to load only the necessary components.

    Testing

    • Write comprehensive tests: Write tests for all critical parts of your application.

    • Use snapshot testing: Use snapshot testing to catch unintended changes.

    Conclusion

    React.js is a powerful library for building modern web applications. By understanding and utilizing its core concepts, you can build efficient, maintainable, and scalable applications. This cheat sheet serves as a comprehensive guide to help you master React.js, covering everything from basic concepts to advanced topics.

    版本聲明 本文轉載於:https://dev.to/raajaryan/comprehensive-reactjs-cheatsheet-for-developers-1col?1如有侵犯,請聯絡[email protected]刪除
    最新教學 更多>
    • 為什麼不````''{margin:0; }`始終刪除CSS中的最高邊距?
      為什麼不````''{margin:0; }`始終刪除CSS中的最高邊距?
      在CSS 問題:不正確的代碼: 全球範圍將所有餘量重置為零,如提供的代碼所建議的,可能會導致意外的副作用。解決特定的保證金問題是更建議的。 例如,在提供的示例中,將以下代碼添加到CSS中,將解決餘量問題: body H1 { 保證金頂:-40px; } 此方法更精確,避免了由全局保證金重置...
      程式設計 發佈於2025-04-02
    • 如何在鼠標單擊時編程選擇DIV中的所有文本?
      如何在鼠標單擊時編程選擇DIV中的所有文本?
      在鼠標上選擇div文本單擊帶有文本內容,用戶如何使用單個鼠標單擊單擊div中的整個文本?這允許用戶輕鬆拖放所選的文本或直接複製它。 在單個鼠標上單擊的div元素中選擇文本,您可以使用以下Javascript函數: function selecttext(canduterid){ if(d...
      程式設計 發佈於2025-04-02
    • 大批
      大批
      [2 數組是對象,因此它們在JS中也具有方法。 切片(開始):在新數組中提取部分數組,而無需突變原始數組。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
      程式設計 發佈於2025-04-02
    • 在細胞編輯後,如何維護自定義的JTable細胞渲染?
      在細胞編輯後,如何維護自定義的JTable細胞渲染?
      在JTable中維護jtable單元格渲染後,在JTable中,在JTable中實現自定義單元格渲染和編輯功能可以增強用戶體驗。但是,至關重要的是要確保即使在編輯操作後也保留所需的格式。 在設置用於格式化“價格”列的“價格”列,用戶遇到的數字格式丟失的“價格”列的“價格”之後,問題在設置自定義單元...
      程式設計 發佈於2025-04-02
    • 如何使用“ JSON”軟件包解析JSON陣列?
      如何使用“ JSON”軟件包解析JSON陣列?
      parsing JSON與JSON軟件包 QUALDALS:考慮以下go代碼:字符串 } func main(){ datajson:=`[“ 1”,“ 2”,“ 3”]`` arr:= jsontype {} 摘要:= = json.unmarshal([] byte(...
      程式設計 發佈於2025-04-02
    • 如何從PHP中的數組中提取隨機元素?
      如何從PHP中的數組中提取隨機元素?
      從陣列中的隨機選擇,可以輕鬆從數組中獲取隨機項目。考慮以下數組:; 從此數組中,使用array_rand( array_rand()函數從數組返回一個隨機鍵。通過將$項目數組索引使用此鍵,我們可以從數組中訪問一個隨機元素。這種方法為選擇隨機項目提供了一種直接且可靠的方法。
      程式設計 發佈於2025-04-02
    • 如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
      如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
      Transform Pandas DataFrame Column to DateTime FormatScenario:Data within a Pandas DataFrame often exists in various formats, including strings.使用時間數據時...
      程式設計 發佈於2025-04-02
    • 為什麼使用固定定位時,為什麼具有100%網格板柱的網格超越身體?
      為什麼使用固定定位時,為什麼具有100%網格板柱的網格超越身體?
      網格超過身體,用100%grid-template-columns 為什麼在grid-template-colms中具有100%的顯示器,當位置設置為設置的位置時,grid-template-colly修復了? 問題: 考慮以下CSS和html: class =“ snippet-code”> ...
      程式設計 發佈於2025-04-02
    • 如何使用Python有效地以相反順序讀取大型文件?
      如何使用Python有效地以相反順序讀取大型文件?
      在python 反向行讀取器生成器 == ord('\ n'): 緩衝區=緩衝區[:-1] 剩餘_size- = buf_size lines = buffer.split('\ n'....
      程式設計 發佈於2025-04-02
    • 哪種方法更有效地用於點 - 填點檢測:射線跟踪或matplotlib \的路徑contains_points?
      哪種方法更有效地用於點 - 填點檢測:射線跟踪或matplotlib \的路徑contains_points?
      在Python Matplotlib's path.contains_points FunctionMatplotlib's path.contains_points function employs a path object to represent the polygon.它...
      程式設計 發佈於2025-04-02
    • 如何使用Regex在PHP中有效地提取括號內的文本
      如何使用Regex在PHP中有效地提取括號內的文本
      php:在括號內提取文本在處理括號內的文本時,找到最有效的解決方案是必不可少的。一種方法是利用PHP的字符串操作函數,如下所示: 作為替代 $ text ='忽略除此之外的一切(text)'; preg_match('#((。 &&& [Regex使用模式來搜索特...
      程式設計 發佈於2025-04-02
    • 我可以將加密從McRypt遷移到OpenSSL,並使用OpenSSL遷移MCRYPT加密數據?
      我可以將加密從McRypt遷移到OpenSSL,並使用OpenSSL遷移MCRYPT加密數據?
      將我的加密庫從mcrypt升級到openssl 問題:是否可以將我的加密庫從McRypt升級到OpenSSL?如果是這樣,如何? 答案:是的,可以將您的Encryption庫從McRypt升級到OpenSSL。 可以使用openssl。 附加說明: [openssl_decrypt()函數要求...
      程式設計 發佈於2025-04-02
    • 如何使用Python的請求和假用戶代理繞過網站塊?
      如何使用Python的請求和假用戶代理繞過網站塊?
      如何使用Python的請求模擬瀏覽器行為,以及偽造的用戶代理提供了一個用戶 - 代理標頭一個有效方法是提供有效的用戶式header,以提供有效的用戶 - 設置,該標題可以通過browser和Acterner Systems the equestersystermery和操作系統。通過模仿像Chro...
      程式設計 發佈於2025-04-02
    • 如何有效地轉換PHP中的時區?
      如何有效地轉換PHP中的時區?
      在PHP 利用dateTime對象和functions DateTime對象及其相應的功能別名為時區轉換提供方便的方法。例如: //定義用戶的時區 date_default_timezone_set('歐洲/倫敦'); //創建DateTime對象 $ dateTime = ne...
      程式設計 發佈於2025-04-02
    • 如何限制動態大小的父元素中元素的滾動範圍?
      如何限制動態大小的父元素中元素的滾動範圍?
      在交互式接口中實現垂直滾動元素的CSS高度限制,控制元素的滾動行為對於確保用戶體驗和可訪問性是必不可少的。一種這樣的方案涉及限制動態大小的父元素中元素的滾動範圍。 問題:考慮一個佈局,其中我們具有與用戶垂直滾動一起移動的可滾動地圖div,同時與固定的固定sidebar保持一致。但是,地圖的滾動無限...
      程式設計 發佈於2025-04-02

    免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

    Copyright© 2022 湘ICP备2022001581号-3