React動(dòng)態(tài)更改html標(biāo)簽的實(shí)現(xiàn)方式
如何動(dòng)態(tài)更改html標(biāo)簽
比如有這樣的一個(gè)需求,子組件通過父組件傳遞過來(lái)的props,來(lái)動(dòng)態(tài)顯示<h1>到<h6>標(biāo)簽,可以先不管react,考慮下vue如何實(shí)現(xiàn)呢?
Vue的實(shí)現(xiàn)方式
父組件
<template> ?? ?<div> ?? ??? ?<Son :tagSize="1"/> ?? ?</div> </template> <script> import Son from '../components/Son'; export default { ? ? name: "Father", ? ? components:{ ? ? ? ? Son ? ? } }; </script>
子組件
<template> ?? ?<div> ? ? ? ? <h1 v-if="tagSize === 1">測(cè)試</h1> ? ? ? ? <h2 v-else-if="tagSize === 2">測(cè)試</h2> ? ? ? ? <h3 v-else-if="tagSize === 3">測(cè)試</h3> ? ? ? ? <h4 v-else-if="tagSize === 4">測(cè)試</h4> ? ? ? ? <h5 v-else-if="tagSize === 5">測(cè)試</h5> ? ? ? ? <h6 v-else>測(cè)試</h6> ?? ?</div> </template> <script> export default { ?? ?name: "Son", ?? ?props: { ?? ??? ?tagSize: { ? ? ? ? ? ? type:Number, ? ? ? ? ? ? default:1 ? ? ? ? } ?? ?} }; </script>
用vue的模板語(yǔ)法我們也是可以實(shí)現(xiàn)以上的需求,但是因?yàn)椴荒軇?dòng)態(tài)html標(biāo)簽顯得不是很靈活,可以想象下,如果可以修改標(biāo)簽,直接通過標(biāo)簽拼接的方式
舉例"<h"+tagSize+">測(cè)試</h"+tagSize+">"的方式,以這種方式來(lái)處理這種需求的話明顯非常方便,廢話不多說,來(lái)看看react的實(shí)現(xiàn)方式。
React的實(shí)現(xiàn)方式
父組件
import React from 'react'; import Child from './Child.js'; class Father extends React.Component{ ? ? render(){ ? ? ? ? return ( ? ? ? ? ? ? <React.Fragment> ? ? ? ? ? ? ? ? <Child size = { 1 }/> ? ? ? ? ? ? </React.Fragment> ? ? ? ? ) ? ? } } export default Father;
子組件
import React from 'react'; const Child = (props)=>{ ? ? let MarkUp = `h${props.size}`; ? ? return ( ? ? ? ? <React.Fragment> ? ? ? ? ? ? <MarkUp>你好</MarkUp> ? ? ? ? </React.Fragment> ? ? ) } export default Child;
相比較兩種方式會(huì)發(fā)現(xiàn)react實(shí)現(xiàn)這類需求會(huì)更合適,react語(yǔ)法采用JSX語(yǔ)法,個(gè)人感覺語(yǔ)法比vue的template模板語(yǔ)法更加靈活,不過Vue現(xiàn)在也已經(jīng)支持JSX。
React修改標(biāo)簽頁(yè)名
React默認(rèn)打開的標(biāo)簽頁(yè)名為React App,那么我們?nèi)绾胃鶕?jù)我們的項(xiàng)目來(lái)全局更改標(biāo)簽頁(yè)名呢?
方法
找到項(xiàng)目中的public文件夾,再找到下面的index.html文件,修改其中的
<title>React App</title>
將其中的React App改為自己想要的名字即可
如果要修改圖標(biāo),同樣在該文件中查找相關(guān)的標(biāo)簽進(jìn)行更改。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
react-draggable實(shí)現(xiàn)拖拽功能實(shí)例詳解
這篇文章主要給大家介紹了關(guān)于react-draggable實(shí)現(xiàn)拖拽功能的相關(guān)資料,React-Draggable一個(gè)使元素可拖動(dòng)的簡(jiǎn)單組件,文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2023-08-08React函數(shù)組件與類組件使用及優(yōu)劣對(duì)比
本文主要介紹了React函數(shù)組件與類組件使用及優(yōu)劣對(duì)比,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04React中useLayoutEffect鉤子使用場(chǎng)景詳解
這篇文章主要為大家介紹了React中useLayoutEffect鉤子使用場(chǎng)景詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12react實(shí)現(xiàn)點(diǎn)擊選中的li高亮的示例代碼
本篇文章主要介紹了react實(shí)現(xiàn)選中的li高亮的示例代碼,頁(yè)面上有很多個(gè)li,要實(shí)現(xiàn)點(diǎn)擊到哪個(gè)就哪個(gè)高亮。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-05-05詳解如何使用React和MUI創(chuàng)建多選Checkbox樹組件
這篇文章主要為大家詳細(xì)介紹了如何使用 React 和 MUI(Material-UI)庫(kù)來(lái)創(chuàng)建一個(gè)多選 Checkbox 樹組件,該組件可以用于展示樹形結(jié)構(gòu)的數(shù)據(jù),并允許用戶選擇多個(gè)節(jié)點(diǎn),感興趣的可以了解下2024-01-01ReactNative中使用Redux架構(gòu)總結(jié)
本篇文章主要介紹了ReactNative中使用Redux架構(gòu)總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2017-12-12react hooks實(shí)現(xiàn)防抖節(jié)流的方法小結(jié)
這篇文章主要介紹了react hooks實(shí)現(xiàn)防抖節(jié)流的幾種方法,文中通過代碼示例給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-04-04