1.iconfont应用:

  a.正常用法如下

<span className='iconfont' > iconfont的代码,例如: </span>

  b.react不能动态渲染iconfont标签,需如下处理,icon为形参

<i dangerouslySetInnerHTML={{__html: icon}} className={'iconfont'} />

  c.引入项目中:需要在项目中复制iconfont的地址代码,类似如下的地址,官网生成

@font-face {
font-family: 'iconfont'; /* project id 413196 */
src: url('//at.alicdn.com/t/font_413196_97fora1hdl81if6r.eot');
src: url('//at.alicdn.com/t/font_413196_97fora1hdl81if6r.eot?#iefix') format('embedded-opentype'),
url('//at.alicdn.com/t/font_413196_97fora1hdl81if6r.woff') format('woff'),
url('//at.alicdn.com/t/font_413196_97fora1hdl81if6r.ttf') format('truetype'),
url('//at.alicdn.com/t/font_413196_97fora1hdl81if6r.svg#iconfont') format('svg');
}

2.排序方法

let dataList=["3","3","45"];
dataList.sort(function(a,b){
return a-b
})
升序方法

3.获取节点属性

需要给DOM节点增加ref属性

4.下拉加载更多数据事件

步骤:a.在滚动滚动div上增加ref属性

<div ref={data=>this.content=data} ></div>

   b.compoonentDidMount中监听滚动事件,并调用判断事件

componentDidMount() {   // 加载渲染完成
if (this.contentNode) {
this.contentNode.addEventListener('scroll',this.onScrollHandle.bind(this));
}
}

   c.判断滚动事件是否触发

//监听滚动条位置
onScrollHandle(event) {
const clientHeight = event.target.clientHeight;
const scrollHeight = event.target.scrollHeight;
const scrollTop = event.target.scrollTop;
const isBottom = (clientHeight + scrollTop === scrollHeight);
isBottom?setTimeout(this.lazy(),20000):"";
}

5.父组件向子组件传值的方式

父组件.js
  html:
    <子组件 parent={(data)=>this.parentEvent(data)} />
  js:
    parentEvent(data){
    //这里接收到的data为子组件传给父组件的
  } 子组件.js
  html:
    <div onClick={this.click.bind(this)}></div>
  js:
    click(){
    this.props.parent(data)//这里的data是传给父组件的
      }

6.字符串的基础操作

函数:split()
功能:使用一个指定的分隔符把一个字符串分割存储到数组
例子:
str=”jpg|bmp|gif|ico|png”;
arr=theString.split(”|”);
//arr是一个包含字符值”jpg”、”bmp”、”gif”、”ico”和”png”的数组 函数:join()
功能:使用您选择的分隔符将一个数组合并为一个字符串
例子:
var myList=new Array(”jpg”,”bmp”,”gif”,”ico”,”png”);
var portableList=myList.join(”|”);
//结果是jpg|bmp|gif|ico|png 函数:substring()
功能:用于提取字符串中介于两个指定下标之间的字符
例子:
“ABCDEF”.substring(0,2) //结果为su 函数:indexOf()
功能:返回字符串中匹配子串的第一个字符的下标
"ABCDEF".indexOf("A") //结果为0
"ABCDEF".indexOf("BC") //结果为1 函数:reverse()
功能:用于颠倒数组中元素的顺序
“05.03.2018”.split(".").reverse().join(".") //结果为2018.03.05

7.正则验证

let reg=/判断格式/
reg.test(需要判断的内容)
返回个布尔值

8.antdUI组件

  a.DatePicker如果需要动态绑定数值的话,不能为空,浏览器会报错;需要对当前是否有值做判断,如果没值,直接赋值null;

  b.DatePicker下的RangePicker,没值的时候可以传空数组,可解决;

9.对象扩展和数组扩展

数组扩展,示例如下:

let arr1=[1,2,3,4]
let arr2=[a,b,c]
let newArr=[...arr1,...arr2]//[1,2,3,4,a,b,c]

对象扩展,示例如下:

let obj1={a:1,b:2,c:3}
let obj2={d:2,e:3,a:45}
Object.assign(obj1,obj2)//{a:45,b:2,c:3,d:2,e:3}

10.当字符串中有需要解析的html字符串时

let a="<span "+">"+"aaaaa"+"</span>";
<p dangerouslySetInnerHTML={{__html:a}}></p>  //p中包含span标签

航遇项目react踩坑的更多相关文章

  1. vue2项目,踩坑Jest单元测试

    目前的项目已经维护了挺久,由于客户要求,我们要为项目加上单元测试,挑选一番后选择了Jest(配置简便,开箱即用),下面记录了此次为项目添加Jest作为单元测试的经历. 安装Jest 1. 在项目目录下 ...

  2. 【React踩坑记一】React项目中禁用浏览器双击选中文字的功能

    常规项目,我们只需要给标签加一个onselectstart事件,return false就可以 例: <div onselectstart="return false;" & ...

  3. 【React踩坑记五】React项目中引入并使用react-ace代码编辑插件(自定义列表提示)

    最近有一个引入sql编辑器插件的需求,要求代码高亮显示,代码智能提示,以及支持自定义代码提示列表等功能.中途在自定义代码提示列表中由于没有相关demo,所以踩了一些坑,遂将其整理如下,以便日后查看. ...

  4. 【React踩坑记四】React项目中引入并使用js-xlsx上传插件(结合antdesign的上传组件)

    最近有一个前端上传并解析excel/csv表格数据的需求. 于是在github上找到一个14K star的前端解析插件 github传送门 官方也有,奈何实在太过于浅薄.于是做了以下整理,避免道友们少 ...

  5. 【React踩坑记六】create-react-app创建的react项目通过iP地址访问(实现局域网内访问)

    同项目组的小伙伴想用自己的电脑访问我电脑上开发阶段的create-react-app创建的react项目. 试过了了各种内网穿透工具ngrok以及localtunnel等. 奈何打开效率实在太过于龟速 ...

  6. 【React踩坑记三】React项目报错Can't perform a React state update on an unmounted component

    意思为:我们不能在组件销毁后设置state,防止出现内存泄漏的情况 分析出现问题的原因: 我这里在组件加载完成的钩子函数里调用了一个EventBus的异步方法,如果监听到异步方法,则会更新state中 ...

  7. 【React踩坑记二】react项目实现JS路由跳转

    这里使用的是4.31版本的react-router-dom "react-router-dom": "^4.3.1", 直接使用以下代码即可实现路由跳转 thi ...

  8. 【React踩坑记三】React项目报错Can't perform a React state update on an unmounted component

    意思为:我们不能在组件销毁后设置state,防止出现内存泄漏的情况 分析出现问题的原因: 我这里在组件加载完成的钩子函数里调用了一个EventBus的异步方法,如果监听到异步方法,则会更新state中 ...

  9. react踩坑笔记

    1.create-react-app中配置webpack // 方法一:将项目的配置文件抽取到项目中,即运行: npm run eject // 方法二:使用react-app-rewired 2.c ...

随机推荐

  1. BLOCK/字面量(语法糖)OC——第六天

    1.//block ,块语法,实质是匿名函数,是对C语言中函数的扩充,扩展: //block  语法可以用来保存一段代码或者用来调用一段封装好的代码: //block  语法由于是C语言实现的,所以执 ...

  2. Oracle中job的实例

    一.Oracle定时器(Job)各时间段写法汇总 对于DBA来说,数据库Job再熟悉不过了,因为经常要数据库定时的自动执行一些脚本,或做数据库备份,或做数据的提炼,或做数据库的性能优化,包括重建索引等 ...

  3. centos vsftpd 553 Could not create file解决方法

    centos vsftpd 553 Could not create file解决方法   问题由于selinux引起的,问题解决办法:   www.2cto.com   输入:getsebool - ...

  4. Win 32 编程之按钮消息响应(代码小错误修复)

    最近不想用MFC写东西了,有没有安装Qt和其他图形化开发环境,只能捣鼓API了.于是乎,就有了以下的学习-- 首先,老套的创建个Windows窗口,由于自己有点小懒,就直接用Hello Word的源码 ...

  5. JavaScript进阶(三)常见工具(校验、通用)

    JS常见工具(校验.通用) // 姓名校验 var checkName = function(name) { // 收货人姓名校验(准则:姓名为2-4汉字) var regu = /^[\u4E00- ...

  6. JavaScript进阶(十一)JsJava2.0版本

    JavaScript进阶(十一)JsJava2.0版本 2007年9月11日,JsJava团队发布了JsJava2.0版本,该版本不仅增加了许多新的类库,而且参照J2SE1.4,大量使用了类的继承和实 ...

  7. uGUI使用代码动态添加Button.OnClick()事件(Unity3D开发之十二)

    猴子原创,欢迎转载.转载请注明: 转载自Cocos2Der-CSDN,谢谢! 原文地址: http://blog.csdn.net/cocos2der/article/details/42705885 ...

  8. SharePoint 添加BCD菜单

    前言:在SharePoint中,我们常见的操作就是添加我们的自定义BCD菜单,下面,简单介绍下添加自定义BCD菜单的操作.主要介绍两种熟悉的方法,一种通过xml方式,另一种是通过js的方式. 环境:S ...

  9. netsh自动配置网络

    工作需要经常在多个网络中切换,每次都要配置ip等,写个脚本一键完成配置: netsh interface ip set address "本地连接" static "ip ...

  10. ASP.NET MVC不可或缺的部分——DI(IOC)容器及控制器重构的剖析(DI的实现原理)

    IoC框架最本质的东西:反射或者EMIT来实例化对象.然后我们可以加上缓存,或者一些策略来控制对象的生命周期,比如是否是单例对象还是每次都生成一个新的对象. DI实现其实很简单,首先设计类来实现接口, ...