新闻下拉加载数据html,Reactjs如何在页面渲染完之后,动态添加子组件,就像jquery的append一样,以实现无限下拉加载数据的功能...

js'use strict';

var React = require('react');

var NewsItemComponent = React.createClass({

render: function() {

return (

{this.props.title}

{this.props.content}

);

}

});

var NewsListComponent = React.createClass({

getInitialState: function() {

return {newsList: []}

},

componentDidMount: function() {

document.addEventListener('scroll', this.handleScroll);

},

componentWillUnmount: function() {

document.removeEventListener('scroll', this.handleScroll);

},

addNews: function(news) {

this.setState({newsList: this.state.newsList.concat(news)});

},

handleScroll: function() {

if (isBottom) {

ajax.request('api').then(this.addNews);

}

},

render: function() {

var newsList = this.state.newsList.map(function(news) {

return ;

});

return (

{newsList}

);

}

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用layui框架进行动态添加下拉组件动态渲染数据时,可以使用下面的代码实现HTML代码: ```html <div class="layui-form-item"> <label class="layui-form-label">下拉框:</label> <div class="layui-input-block"> <select name="select" lay-filter="select"> <option value="">请选择</option> </select> </div> </div> ``` JavaScript代码: ```javascript layui.use(['form', 'jquery'], function(){ var form = layui.form; var $ = layui.jquery; // 动态渲染下拉数据 function renderSelect() { var data = [{value: 1, text: '选项1'}, {value: 2, text: '选项2'}, {value: 3, text: '选项3'}]; var select = $('select[name=select]'); select.empty(); select.append('<option value="">请选择</option>'); layui.each(data, function(index, item){ select.append('<option value="'+ item.value +'">'+ item.text +'</option>'); }); form.render('select'); } // 动态添加下拉组件 function addSelect() { var html = '<div class="layui-form-item">'+ '<label class="layui-form-label">下拉框:</label>'+ '<div class="layui-input-block">'+ '<select name="select" lay-filter="select">'+ '<option value="">请选择</option>'+ '</select>'+ '</div>'+ '</div>'; $('.layui-form').append(html); renderSelect(); } // 初始化页面 renderSelect(); // 点击按钮添加下拉组件 $('#addSelect').click(function(){ addSelect(); }); // 监听下拉框选中事件 form.on('select(select)', function(data){ console.log(data.value + ' ' + data.elem[data.elem.selectedIndex].text); }); }); ``` 在上述代码中,首先使用`layui.use`方法加载`form`和`jquery`模块,然后定义了两个函数`renderSelect`和`addSelect`,分别用于动态渲染下拉数据动态添加下拉组件。在`renderSelect`函数中,通过定义一个数据数组,然后遍历该数组,动态添加下拉框选项,并调用`form.render('select')`方法进行渲染。在`addSelect`函数中,通过拼接HTML代码,动态添加一个下拉组件,并调用`renderSelect`函数进行数据渲染。最后,在页面加载毕后,调用`renderSelect`函数进行初始化,并监听下拉框选中事件,输出选中的值和文本。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值