react 0至1 【jsx】

1.函数调用 
// 项目的根组件
// App -> index.js -> public/index.html(root)

const count = 100

function getName () {
  return 'test'
}

function App () {
  return (
    <div className="App">
      this is App
      {/* 使用引号传递字符串 */}
      {'this is message'}
      {/* 识别js变量 */}
      {count}
      {/* 函数调用 */}
      {getName()}
      {/* 方法调用 */}
      {new Date().getDate()}
      {/* 使用js对象 */}
      <div style={{ color: 'red' }}>this is div</div>
    </div>
  )
}

export default App
2.列表渲染
const list = [
  { id: 1001, name: 'Vue' },
  { id: 1002, name: 'React' },
  { id: 1003, name: 'Angular' }
]

function App () {
  return (
    <div className="App">
      this is App
      {/* 渲染列表 */}
      {/* map 循环哪个结构 return结构 */}
      {/* 注意事项:加上一个独一无二的key 字符串或者number id */}
      {/* key的作用:React框架内部使用 提升更新性能的 */}
      <ul>
        {list.map(item => <li key={item.id}>{item.name}</li>)}
      </ul>
    </div>
  )
}

export default App

3.条件渲染 

const isLogin = true

function App () {
  return (
    <div className="App">
      {/* 逻辑与 && */}
      {isLogin && <span>this is span</span>}
      {/* 三元运算 */}
      {isLogin ? <span>jack</span> : <span>loading...</span>}
    </div>
  )
}

export default App
// 定义类型
const articleType = 3  // 0 1 3

// 定义核心函数(根据类型返回不同的JSX模版)

function getArticleTem () {
  if (articleType === 0) {
    return <div>文章1</div>
  } else if (articleType === 1) {
    return <div>文章2</div>
  } else {
    return <div>文章3</div>
  }
}

function App () {
  return (
    <div className="App">
      {/* 调用函数渲染不同的模版 */}
      {getArticleTem()}
    </div>
  )
}

export default App
 4.事件绑定
function App () {
  // 基础绑定
  const handleClick = () => {
    console.log('button被点击了')
  }

  // 事件参数e
  // const handleClick = (e) => {
  //   console.log('button被点击了', e)
  // }

  // 传递自定义参数
  const handleClick = (name) => {
    console.log('button被点击了', name)
  }

  // 既要传递自定义参数 而且还要事件对象e
  const handleClick = (name, e) => {
    console.log('button被点击了', name, e)
  }
  return (
    <div className="App">
      <button onClick={(e) => handleClick('jack', e)}>click me </button>
    </div>
  )
}

export default App

相关推荐

  1. react 01jsx

    2024-06-12 08:12:02       33 阅读
  2. react 01 基础使用

    2024-06-12 08:12:02       32 阅读
  3. <span style='color:red;'>react</span>-<span style='color:red;'>jsx</span>

    react-jsx

    2024-06-12 08:12:02      39 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-12 08:12:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-12 08:12:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-12 08:12:02       82 阅读
  4. Python语言-面向对象

    2024-06-12 08:12:02       91 阅读

热门阅读

  1. 一个有趣的c++案例

    2024-06-12 08:12:02       22 阅读
  2. “手撕”二叉树的OJ习题

    2024-06-12 08:12:02       24 阅读
  3. jQuery Ajax 基本用法 附带Fetch API

    2024-06-12 08:12:02       29 阅读
  4. cd和pwd命令

    2024-06-12 08:12:02       26 阅读
  5. Date类

    2024-06-12 08:12:02       24 阅读
  6. LINUX

    LINUX

    2024-06-12 08:12:02      29 阅读
  7. Mongodb学习

    2024-06-12 08:12:02       27 阅读
  8. 【每日一题】01

    2024-06-12 08:12:02       22 阅读