React开发实践(6)实战部分 Header 组件开发 1

简介: React开发实践(6)实战部分 Header 组件开发 1
  • 此处 以 简书为例子 实战一下 敲一敲

1、项目目录搭建 开始

1、新建一个 空的 react 项目 并清空 内容 npx create-react-app my-app-jianshu-react
2、注意 index.css 在 index.js 引入后其他部分也可使用,但css 样式可能产生冲突
3、解决上面那个问题 安装 css yarn add styled-components 
4、使用这个 东西 写全局样式 和组件自身样式 
5、为了统一在浏览器的表现形式,需要使用 reset.css https://meyerweb.com/eric/tools/css/reset/ 将这个网站的内容拿过来 
复制代码
  • 清理代码 只显示 hello

网络异常,图片无法展示
|

网络异常,图片无法展示
|

* 安装 yarn add styled-components 管理 css

  • 将原本的 index.css 更改为 style.js 并且在 index.js 中引入

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

2、Header 组件布局

1、新建文件夹 common
    2、文件夹内 加一个 header文件夹 创建 index.js 和 style.js
    3、在 index.js 引入使用 
    4、
    5、
复制代码
  • 等会儿 敲完

*style.js

网络异常,图片无法展示
|

  • index.js 此处 使用

网络异常,图片无法展示
|

  • 页面效果

网络异常,图片无法展示
|

  • 点击 这个 logo 图片 刷新本页面

网络异常,图片无法展示
|

将其他部分 补充一下

  • 值得注意的是 有时 为了扩充整个 width 需要设置 容器为 box-sizing: border-box

* style.js

import logoPic from "../../statics/logo.png";
export const HeaderWrapper = styled.div`
  position: relative;
  height: 56px;
  padding-bottom: 1px solid #f0f0f0;
`;
export const Logo = styled.a.attrs({ href: "/" })`
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100px;
  height: 56px;
  background: url(${logoPic});
  background-size: contain;
`;
export const Nav = styled.div`
  width: 960px;
  height: 100%;
  background: pink;
  margin: 0 auto;
  padding-right: 70px;
  box-sizing: border-box;
`;
export const NavItem = styled.div`
  font-size: 17px;
  padding: 0 15px;
  cursor: pointer;
  line-height: 56px;
  &.left {
    float: left;
  }
  &.right {
    float: right;
    color: #969696;
  }
  &.active {
    color: #ea6f5a;
  }
`;
export const NavSearch = styled.input.attrs({ placeholder: "搜索" })`
  width: 160px;
  height: 38px;
  padding: 0 20px;
  background: #eee;
  border-radius: 19px;
  border: none;
  margin-top: 9px;
  font-size: 14px;
`;
export const Addition = styled.div`
  position: absolute;
  right: 0;
  top: 0;
  height: 56px;
`;
export const Button = styled.div`
  float: right;
  margin-right: 20px;
  line-height: 38px;
  margin-top: 9px;
  padding: 0 20px;
  border-radius: 19px;
  border: 1px solid #ea6f5a;
  &.reg {
    color: #ea6f5a;
  }
  &.write {
    background: #ea6f5a;
    color: #fff;
  }
`;
复制代码
  • header index.js
import {
  HeaderWrapper,
  Logo,
  Nav,
  NavItem,
  NavSearch,
  Addition,
  Button,
} from "./style";
class Header extends Component {
  constructor(props) {
    super(props);
    this.state = {};
  }
  render() {
    return (
      <>
        <HeaderWrapper>
          <Logo />
          <Nav>
            <NavItem className="left active">首页</NavItem>
            <NavItem className="left">下载APP</NavItem>
            <NavSearch></NavSearch>
            <NavItem className="right">登陆</NavItem>
            <NavItem className="right">Aa</NavItem>
          </Nav>
          <Addition>
            <Button className="write">写文章</Button>
            <Button className="reg">注册</Button>
          </Addition>
        </HeaderWrapper>
      </>
    );
  }
}
export default Header;
复制代码

*实现效果

网络异常,图片无法展示
|

3、使用 iconfont 嵌入头部图标

1、打开 iconfont.cn 登陆后 新建项目 
2、选择需要的东西 然后 下载到本地 (此处使用下载本地后改成在线链接 有点问题)
3、然后 在 src 下新建一个 iconfont 文件夹 将这些东西放进去 
4、然后 将.css 更改后缀为 .js 使用 styled 更改为全局样式
5、在index 中 引入样式 则可生效 
6、
复制代码

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

  • 引入 全局 iconfont

网络异常,图片无法展示
|

  • 页面上这种 形式使用

网络异常,图片无法展示
|

  • 注意这种两个东西的内外层定位

网络异常,图片无法展示
|

网络异常,图片无法展示
|

  • 实现效果 非常 nice !

网络异常,图片无法展示
|

4、搜索框动画效果实现

1、首先 调整一下 输入框的内容和 搜索框的 间距
2、然后 react 当中 不要直接操作 dom 选择 数据驱动 视图变化
3、添加一个 state 为 isFocused 默认值为 false 
4、给 input 绑定 onChange 事件和 onBlur 事件 
复制代码

网络异常,图片无法展示
|

网络异常,图片无法展示
|

  • 此处有个小技巧先设置 isFocused 为 true 调整一下 效果

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

  • 然后添加 事件驱动 改变 state

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

  • 添加动画效果
1、使用 之前那个 动画库   yarn add react-transition-group
 2、引入后包裹需要动画的内容 input 上
 3、写属性
 4、写 样式 
 5、查看效果
复制代码

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

  • 当前页面 可以 看到 动画的过渡效果 非常的nice !

5、使用 react-redux 进行 页面数据管理  

  • 非常精彩的 redux 又来啦
1、yarn add redux           yarn add react-redux  (安装完 重启服务)
  2、目的是将组件内的 isFocused 放到 redux 中管理 
  3、首先 App 中需要 用 Provider 包裹 Header 组件 并 传入 store={store}
  这样 Provider 包裹的部分 就可拿到 store 的数据
  4、需要在组件内 使用 connect 方法 连接 使用数据 
  5、 注意 connect(mapStateToProps,mapDispatchToProps)(Header) 两个参数
  6、然后就是 经典的想更改 store 数据的流程  创建 action --> store.dispatch(action) --> store ---> (prevState, action) --> reducer --> newState --> store --> components
复制代码

* ok 我们开始敲一遍

* APP.js

网络异常,图片无法展示
|

  • store/index.js

网络异常,图片无法展示
|

  • store/reducer.js

网络异常,图片无法展示
|

  • 组件 Header.js

网络异常,图片无法展示
|

网络异常,图片无法展示
|

*redux 流程

网络异常,图片无法展示
|

  • 组件上面 原本的 this.state  都更改为 this.props

* 更新后的 reducer.js

网络异常,图片无法展示
|

  • 页面效果 非常的nice !
  • 此时发现 由于页面 没有 管理 state 状态 直接更改为 function组件

网络异常,图片无法展示
|

  • 非常nice !

6、使用 combinReducers 完成对数据的拆分管理

1、添加 dev tools 
    2、header 文件夹下 新建 store/reducer.js  index.js
    3、将之前的 reducer 内容 移动到 header 下面 reducer
    4、注意 此时层级结构 发生了改变  组件内 取 state 时 需要更改
    5、
复制代码
  • store index.js

网络异常,图片无法展示
|

  • store/reducer.js  index.js

网络异常,图片无法展示
|

网络异常,图片无法展示
|

*src/ store / reducer.js

网络异常,图片无法展示
|

  • 结构变更 页面 需要更改

网络异常,图片无法展示
|

网络异常,图片无法展示
|

  • 非常 nice !

7、actionCreators 和 constants 的拆分

1、header 下 新建 actionCreators  constants
2、然后 将这两个引入 到 header 下的 store/index.js
3、这样在其他地方 引入 就变得更加的简单了
复制代码
  • 重点在于 index.js 这样写 使得 全部都简化了

网络异常,图片无法展示
|

  • actionCreators.js

网络异常,图片无法展示
|

* 常量管理 constants

网络异常,图片无法展示
|

  • 页面使用

网络异常,图片无法展示
|

网络异常,图片无法展示
|

  • 尝试效果后 非常 nice !

撒花 🎉🎉🎉

更多项目请访问 github  github.com/huanhunmao

gitee 项目地址 gitee.com/huanhunmao/…


相关文章
|
1月前
|
设计模式 存储 前端开发
React开发设计模式及原则概念问题之自定义Hooks的作用是什么,自定义Hooks设计时要遵循什么原则呢
React开发设计模式及原则概念问题之自定义Hooks的作用是什么,自定义Hooks设计时要遵循什么原则呢
|
2月前
|
前端开发 JavaScript 安全
TypeScript在React Hooks中的应用:提升React开发的类型安全与可维护性
【7月更文挑战第17天】TypeScript在React Hooks中的应用极大地提升了React应用的类型安全性和可维护性。通过为状态、依赖项和自定义Hooks指定明确的类型,开发者可以编写更加健壮、易于理解和维护的代码。随着React和TypeScript的不断发展,结合两者的优势将成为构建现代Web应用的标准做法。
|
4月前
|
前端开发 JavaScript 程序员
开发语言漫谈-React
React同Vue一样,都是基于Javascript上的框架,不是独立语言
|
21天前
|
JavaScript 前端开发 安全
[译] 使用 TypeScript 开发 React Hooks
[译] 使用 TypeScript 开发 React Hooks
|
1月前
|
移动开发 前端开发 JavaScript
"跨界大战!React Native、Weex、Flutter:三大混合开发王者正面交锋,揭秘谁才是你移动应用开发的终极利器?"
【8月更文挑战第12天】随着移动应用开发的需求日益增长,高效构建跨平台应用成为关键。React Native、Weex与Flutter作为主流混合开发框架各具特色。React Native依托Facebook的强大支持,以接近原生的性能和丰富的组件库著称;Weex由阿里巴巴开发,性能优越尤其在大数据处理上表现突出;Flutter则凭借Google的支持及独特的Dart语言和Skia渲染引擎,提供出色的定制能力和开发效率。选择时需考量项目特性、团队技能及生态系统的成熟度。希望本文对比能助你做出最佳决策。
101 1
|
1月前
|
前端开发
React——开发调式工具安装【五】
React——开发调式工具安装【五】
23 0
React——开发调式工具安装【五】
|
19天前
|
前端开发 JavaScript Android开发
React Native 快速入门简直太棒啦!构建跨平台移动应用的捷径,带你开启高效开发之旅!
【8月更文挑战第31天】React Native凭借其跨平台特性、丰富的生态系统及优异性能,成为移动应用开发的热门选择。它允许使用JavaScript和React语法编写一次代码即可在iOS和Android上运行,显著提升开发效率。此外,基于React框架的组件化开发模式使得代码更加易于维护与复用,加之活跃的社区支持与第三方库资源,加速了应用开发流程。尽管作为跨平台框架,React Native在性能上却不输原生应用,支持原生代码优化以实现高效渲染与功能定制。对于开发者而言,React Native简化了移动应用开发流程,是快速构建高质量应用的理想之选。
28 0
|
19天前
|
前端开发 JavaScript 数据管理
React Formik入门:简化表单处理的神器——全面掌握Formik在React表单开发中的高效应用与实战技巧
【8月更文挑战第31天】在React应用中,表单处理常常因繁琐而令人头疼。Formik作为一个开源库,专为简化React表单设计,减少冗余代码并提升处理效率。本文介绍Formik的使用方法及其优势,通过示例展示如何安装配置并创建基本表单,帮助开发者轻松应对各种表单需求。
24 0
|
19天前
|
前端开发 JavaScript 测试技术
React 与前端自动化测试也太重要啦!各种测试框架助力确保应用质量,快来开启优质开发之旅!
【8月更文挑战第31天】随着前端技术的发展,React 成为了构建用户界面的热门选择。然而,随着应用复杂性的增加,确保应用质量变得至关重要。本文介绍了前端自动化测试的重要性,并详细综述了常用的测试框架如 Jest、Enzyme 和 Cypress,以及如何通过它们进行高效的 React 组件测试。通过遵循最佳实践,如编写可维护的测试用例、覆盖关键场景、集成 CI/CD 流程和进行性能测试,可以显著提高应用的稳定性和可靠性。
26 0
|
30天前
|
JavaScript 前端开发 安全

热门文章

最新文章