javascript - react 組件中的虛擬DOM 操作
問題描述
闡述: 本人是 reactJS 的初學者 ;需求如下: 1、react 組件 aa.jsx
var React = require(’react’); var aaa = React.createClass({render: function(){ return (<p ref='username' className='comment2'> aaaaaaaaa</p> );} }); module.exports = aaa;
2、react 組件 bb.jsx
var React = require(’react’); var aaa = React.createClass({render: function(){ return (<p ref='username' className='comment3'> bbbbbbbbbbbbbbb</p> );} }); module.exports = bbb;
3、react 主入口 main.jsx 需要 根據 一個 json 文件來加載 所需的組件
json ={ 'data' : [{ 'page' : 'aa'},{ 'page' : 'bb'},{ 'page' : 'cc'} ]} 在主函數這里 我用了一個for 循環 for (var i=0 ; i< data.length ; i++){var page = require(’./components/’+ data[i][’page’] +’.jsx’); }
但是問題來, 在這里的page 都是 一個個的 函數。 怎樣 將其中的 dom 塊(p 元素) 取出來 一個個有序的 添加到 index.html 頁面上的 某個指定的 dom元素中去 。
問題解答
回答1:首先我不明白的是,你的 aa.jsx 和 bb.jsx 既然那么像,為什么還寫兩個(當然也可能是你為了方便寫例子)。既然是多個不同的文件,它就是不同的 React 組件,如果只是想把它們都渲染在某個 DOM 下,直接把它們放到一個數組就好。
下面的代碼我沒有測試,但應該是能用的
const components = [];for (var i=0 ; i< data.length ; i++){ var Page = require(’./components/’+ data[i][’page’] +’.jsx’); components.push(<Page />);}
在要嵌入的地方,JSX 代碼
<FatherComponent> {components}</FatherComponent>
如果是要隨時更新它,重新渲染就行了,可以用 this.state.components
你可以來看看我們翻譯的 React 文檔
回答2:這跟虛擬dom沒關系,雖然我不知道你為什么這樣用~但你這樣用法就是錯的!
相關文章:
1. 求救一下,用新版的phpstudy,數據庫過段時間會消失是什么情況?2. python沒入門,請教一個問題3. 小程序怎么加外鏈,語句怎么寫!求救新手,開文檔沒發現4. php如何獲取訪問者路由器的mac地址5. html - 爬蟲時出現“DNS lookup failed”,打開網頁卻沒問題,這是什么情況?6. javascript - 我的站點貌似被別人克隆了, google 搜索特定文章,除了域名不一樣,其他的都一樣,如何解決?7. 求教一個mysql建表分組索引問題8. node.js - 用nodejs 的node-xlsx模塊去讀取excel中的數據,可是讀取出來的日期是數字,請問該如何讀取日期呢?9. html5 - input type=’file’ 上傳獲取的fileList對象怎么存儲于瀏覽器?10. javascript - 在 vue里面用import引入js文件,結果為undefined
