# day001 **Repository Path**: yang-wanting/day001 ## Basic Information - **Project Name**: day001 - **Description**: No description available - **Primary Language**: Unknown - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-10-26 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README #### day01: 1, react基本语法: ​ 安装运行项目: ``` npm start ``` JSX语法: React 使用 JSX 来替代常规的 JavaScript。 他的优点是: 执行更快,编译为 JavaScript 代码后进行了优化; 类型安全的,在编译过程中就能轻易的找出错误; 简单快速; 2,父子传值,兄弟通信: #### 父传子 父组件通过props向子组件传递数据 **子组件** ```React import React from 'react'; import PropTypes from 'prop-types'; export default function Child({ name }) { return

Hello, {name}

; } Child.propTypes = { name: PropTypes.string.isRequired, }; ``` **父组件** ```react import React, { Component } from 'react'; import Child from './Child'; class Parent extends Component { render() { return (
); } } export default Parent; ``` 3,rem布局原理的实现: rem是根据根元素的大小来设置具体大小的,当一个屏幕的宽度会变成另一个屏幕的宽度,里面设置的元素会跟着屏幕的宽度增大而增大,是成正比例函数的。 而且rem是相对单位,是根据不同的屏幕大小而改变的,是适配不同屏幕的。 实现代码如下: ``` (function(designWidth, maxWidth) { var doc = document, win = window; var docEl = doc.documentElement; var tid; var rootItem,rootStyle; function refreshRem() { var width = docEl.getBoundingClientRect().width; if (!maxWidth) { maxWidth = 540; }; if (width > maxWidth) { width = maxWidth; } //与淘宝做法不同,直接采用简单的rem换算方法1rem=100px var rem = width * 100 / designWidth; //兼容UC开始 rootStyle="html{font-size:"+rem+'px !important}'; rootItem = document.getElementById('rootsize') || document.createElement("style"); if(!document.getElementById('rootsize')){ document.getElementsByTagName("head")[0].appendChild(rootItem); rootItem.id='rootsize'; } if(rootItem.styleSheet){ rootItem.styleSheet.disabled||(rootItem.styleSheet.cssText=rootStyle) }else{ try{rootItem.innerHTML=rootStyle}catch(f){rootItem.innerText=rootStyle} } //兼容UC结束 docEl.style.fontSize = rem + "px"; }; refreshRem(); win.addEventListener("resize", function() { clearTimeout(tid); //防止执行两次 tid = setTimeout(refreshRem, 300); }, false); win.addEventListener("pageshow", function(e) { if (e.persisted) { // 浏览器后退的时候重新计算 clearTimeout(tid); tid = setTimeout(refreshRem, 300); } }, false); if (doc.readyState === "complete") { doc.body.style.fontSize = "16px"; } else { doc.addEventListener("DOMContentLoaded", function(e) { doc.body.style.fontSize = "16px"; }, false); } })(640, 640); ``` #### 4,object.defineProperty()方法有何作用? 作用:它是得到一个属性,或者获取一个新的属性,精确地修改属性。 基本用法: writeable:可写入的权限; value:可写入的值;![](C:\Users\DeLL\Desktop\1.png) setter:是功能描述符,是可以设置属性的; getter:功能描述符,是可以获取属性的; 具体实现: 它是通过监听者触发data里面的定义的属性,发布页面,实时进行数据解析器的监听,通过setter和getter里面的set和get方法获取到触发的变化,进而实现效果。