react項目如何運行在微信公眾號
說明:項目是create-react-app結(jié)合antd-mobile寫的H5,在微信公眾號里運行。
1、使用a標(biāo)簽預(yù)覽或下載PDF。寫法如下,手機上點擊無反應(yīng),電腦上點擊網(wǎng)頁崩潰。
<a href='pdf或圖片路徑'> PDF或圖片名稱 </a>
原因是瀏覽器監(jiān)測到訪問非安全訪問,給攔截下來了。于是根據(jù)報錯提示,新增target和rel兩個屬性,寫法如下:
<a href='pdf或圖片路徑' target='_blank' rel="noreferrer"> PDF或圖片名稱 </a>
在電腦上和iOS上均可正常查看。
不過,在安卓上有以下幾種情況:
a) 手機自帶有QQ瀏覽器,直接就打開PDF。(這種情況是正常預(yù)覽)
b) 手機上沒有QQ瀏覽器,但是有其他瀏覽器,會彈出一個框,提示下載QQ瀏覽器或用其他瀏覽器打開。(這種也是正常預(yù)覽下載)
c) 手機上沒有QQ瀏覽器,但是有其他瀏覽器,點擊PDF文件的時候,能夠看到一個加載條加載效果,但是過后既不預(yù)覽,也不提示。(這種是非正常的,微信禁止了)在a標(biāo)簽上加一個download屬性可出現(xiàn)效果b)。
<a href='pdf或圖片路徑' target='_blank' rel="noreferrer" download> PDF或圖片名稱 </a>
另外,如果需要直接預(yù)覽PDF的話,可以使用react-pdf-js插件,缺點是,當(dāng)pdf文件稍微有點大的時候,加載顯示極慢,所以還是建議上面的方式。
2、使用antd-mobile長列表listView做長列表加載。(提供給各位一個做移動端長列表的備選方案)
3、項目初的時候,一運行起來就報各種缺babel插件的問題,找了兩個多小時找到原因,webpack的配置文件中,plugins里多配置了兩個插件,而在項目中沒有安裝且不需要這兩個插件,所以,在配置里去掉后再運行,就沒有報錯了。
4、echarts畫地圖和柱圖
a) 畫中國地圖
v5開始不提供地圖輪廓數(shù)據(jù),選用v4.9.0版本,好處是既有地圖輪廓數(shù)據(jù),地圖上省份名稱也居中了。地圖上的浮層是在tooltip里面配置,可以不專門添加position,它默認(rèn)顯示的位置是靈活的。
b) 畫柱圖
v4版本無排序的API,如果柱圖數(shù)據(jù)需要排序,盡量跟后端同學(xué)溝通,讓其排好序把數(shù)據(jù)返給你。如果沒溝通好,我們這邊也可以處理,寫一個排序函數(shù)即可。
5、使用useRef綁定值做操作,可以直接綁定在DOM上。
寫后臺系統(tǒng)的話,通常都是直接引入UI組件,但是在移動端就對UI有要求,在UI庫引入組件改樣式也挺麻煩。以Input標(biāo)簽舉例:
UI庫的Input組件可以輕松實現(xiàn)雙向綁定,但是有自帶樣式,要跟設(shè)計畫的輸入框樣式保持一樣就比較艱難。
原生的html標(biāo)簽——input??梢宰远x樣式,但是雙向綁定就沒有了,比如登錄頁,需要輸入賬戶密碼,使用js的方法可以拿到賬戶密碼,但是需要自己寫很多代碼。這個時候,useRef就是較好的選擇了,與useState,useEffect一樣,它是react的hooks函數(shù)。使用如下:
import { useState,useRef } from 'react'; //引入
const inputRef = useRef<any>(); //定義
const [phone, setPhone] = useState("");
export default const Login= () =>{
const changePhone = () => {
setPhone(inputRef?.current?.value)
}
return (
/*綁定在input標(biāo)簽上*/
<input value={phone} ref={inputRef} onChange={changePhone} maxLength={11} placeholder='請輸入手機號' />
)
}
6、封裝組件小理念
單一職責(zé)原則:一個組件只做一件事。如果組件變得復(fù)雜,就再拆分成小組件。
以上就是react項目如何運行在微信公眾號的詳細(xì)內(nèi)容,更多關(guān)于react運行在微信公眾號的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
ReactNative錯誤采集原理在Android中實現(xiàn)詳解
這篇文章主要為大家介紹了ReactNative錯誤采集原理在Android中實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
React?Native實現(xiàn)Toast輕提示和loading效果
這篇文章主要介紹了React Native實現(xiàn)Toast輕提示和loading效果,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09
使用 Rails API 構(gòu)建一個 React 應(yīng)用程序的詳細(xì)步驟
這篇文章主要介紹了使用 Rails API 構(gòu)建一個 React 應(yīng)用程序的詳細(xì)步驟,主要包括后端:Rails API部分,前端:React部分及React組件的相關(guān)操作,具有內(nèi)容詳情跟隨小編一起看看吧2021-08-08
react-redux中connect的裝飾器用法@connect詳解
這篇文章主要介紹了react-redux中connect的裝飾器用法@connect詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-01-01

