This time I will bring you how to use React to complete a picture carousel component. What are the notes of using React to complete a picture carousel component? The following is a practical case. Get up and take a look.
Use React to implement the above functions. First, divide the components:
<SlideMS> <SlideM/> <SlideS/><SlideMS/>
The component SlideM represents the middle picture component, which always maintains a state: currentMIndex, which is the index value of the current Chinese image.
The component SlideS represents the small picture component and needs to maintain two states: currentSIndex and currentSPage, that is, the index value of the current small picture image and the current page number of the small picture;
The outer component SlideMS accepts several Parameters as props:
<SlideMS mediumImageArr={mediumImageArr} eachMediumImgWidth = {616} smallImageArr={smallImageArr} eachSmallImgWidth = {82}/>, document.getElementById('js-img-slide')); SlideM、SlideS再从SlideMS中获取参数进行内部渲染。 <SlideM mediumImageArr={mediumImageArr} currentMIndex={currentMIndex} eachMediumImgWidth = {eachMediumImgWidth} callback={(index)=>{self.setSmallIndex(index)}} /><SlideS smallImageArr={smallImageArr} currentSIndex={currentSIndex} eachSmallImgWidth={eachSmallImgWidth} eachMediumImgWidth = {eachMediumImgWidth} callback={(index)=>{self.setMediumIndex(index)}}/>
When the switch button of the middle image is clicked, the image offset is calculated, and then the new currentMIndex is passed to the parent component. The parent component setState notifies the two child components of the currentMIndex. Changes have occurred;
There are many calculations involved in the small picture component, and these can be divided into methods, such as: calculating how many small pictures there are on a page based on the given width of the middle picture, calculating the total number of small picture pages, Determine which page the thumbnail is on based on the given index value.
When you click the left and right arrows of the small picture component, calculate the offset of the picture (first calculate how many small pictures there are in a medium picture), and then setState modifies the value of the currentSPage of the small picture. The parent component setState notifies the two sub-components that the currentMIndex has changed;
After the medium picture and small picture components received the new value changes in componentWillReceiveProps respectively, they setState again and updated the state inside the component, thus realizing the two communication between persons.
The above is an idea for implementation. In actual applications, the scene will be more complicated. For example, the first picture may need to play a video, and when the middle picture is clicked, it can be switched to the large picture mode. In the large picture mode, the carousel can be normal, and in When the large picture mode is turned off, the medium picture and small picture will automatically locate the last picture viewed just now. This will involve slightly more complex operations, and compatibility needs to be done on this basis.
A very embarrassing point: the animation effect during image carousel still uses jquery’s animate.
The above is the detailed content of Complete an image carousel component using React. For more information, please follow other related articles on the PHP Chinese website!

The future trends of HTML are semantics and web components, the future trends of CSS are CSS-in-JS and CSSHoudini, and the future trends of JavaScript are WebAssembly and Serverless. 1. HTML semantics improve accessibility and SEO effects, and Web components improve development efficiency, but attention should be paid to browser compatibility. 2. CSS-in-JS enhances style management flexibility but may increase file size. CSSHoudini allows direct operation of CSS rendering. 3.WebAssembly optimizes browser application performance but has a steep learning curve, and Serverless simplifies development but requires optimization of cold start problems.

The roles of HTML, CSS and JavaScript in web development are: 1. HTML defines the web page structure, 2. CSS controls the web page style, and 3. JavaScript adds dynamic behavior. Together, they build the framework, aesthetics and interactivity of modern websites.

The future of HTML is full of infinite possibilities. 1) New features and standards will include more semantic tags and the popularity of WebComponents. 2) The web design trend will continue to develop towards responsive and accessible design. 3) Performance optimization will improve the user experience through responsive image loading and lazy loading technologies.

The roles of HTML, CSS and JavaScript in web development are: HTML is responsible for content structure, CSS is responsible for style, and JavaScript is responsible for dynamic behavior. 1. HTML defines the web page structure and content through tags to ensure semantics. 2. CSS controls the web page style through selectors and attributes to make it beautiful and easy to read. 3. JavaScript controls web page behavior through scripts to achieve dynamic and interactive functions.

HTMLisnotaprogramminglanguage;itisamarkuplanguage.1)HTMLstructuresandformatswebcontentusingtags.2)ItworkswithCSSforstylingandJavaScriptforinteractivity,enhancingwebdevelopment.

HTML is the cornerstone of building web page structure. 1. HTML defines the content structure and semantics, and uses, etc. tags. 2. Provide semantic markers, such as, etc., to improve SEO effect. 3. To realize user interaction through tags, pay attention to form verification. 4. Use advanced elements such as, combined with JavaScript to achieve dynamic effects. 5. Common errors include unclosed labels and unquoted attribute values, and verification tools are required. 6. Optimization strategies include reducing HTTP requests, compressing HTML, using semantic tags, etc.

HTML is a language used to build web pages, defining web page structure and content through tags and attributes. 1) HTML organizes document structure through tags, such as,. 2) The browser parses HTML to build the DOM and renders the web page. 3) New features of HTML5, such as, enhance multimedia functions. 4) Common errors include unclosed labels and unquoted attribute values. 5) Optimization suggestions include using semantic tags and reducing file size.

WebdevelopmentreliesonHTML,CSS,andJavaScript:1)HTMLstructurescontent,2)CSSstylesit,and3)JavaScriptaddsinteractivity,formingthebasisofmodernwebexperiences.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Atom editor mac version download
The most popular open source editor

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

Zend Studio 13.0.1
Powerful PHP integrated development environment