React:styled-components
``是es6的Template Literals(模版字符串),许多人对这个一知半解,今天在这边总结下:
`${expression}`(表达式插补)
var x;
var y;
sth.innerHTML = `相对当前盒子坐标:x轴:${x},y轴:${y}`
这样表示少了很多代码量并且提高了阅读性,不然你需要用+““+来拼接字符串,将拼接字符串更简单的表示出来,再举栗子
var a = 5;
var b = 10;
console.log("Fifteen is " + (a + b) + " and\nnot " + (2 * a + b) + ".");
// "Fifteen is 15 and
// not 20."
模版表示法(${}里面是js表达式,所以包括变量等)
var a = 5;
var b = 10;
console.log(`Fifteen is ${a + b} and\nnot ${2 * a + b}.`);
// "Fifteen is 15 and
// not 20."
多行字符串
console.log("string text line 1\n\
string text line 2");
// "string text line 1
// string text line 2"
模版字符串表示法
console.log(`string text line 1
string text line 2`);
// "string text line 1
// string text line 2"
只是简单加了个回车
主要讲讲styled-components里面的语法,用过这个框架的人都知道,定义一个包含样式的h1:styled.h1`font-size:1.5em;.....`,这里面就涉及到了模版字符串,一开始不知道为什么这样写,以为又是什么高科技,测试完才发现其实:
styled.h1`
font-size:1.5em;
`
就等于如下
styled.h1("font-size:1.5em;")
为什么这样说呢?
我们来看一个测试:
现在控制台定义一个函数:
//在浏览器控制台输入
//这个函数的意思就是输出这个函数的所有参数,js中的rest用法
const f = (...args) => {console.log(...args)}
在控制台输入:f(123) 或者 f('123')都是正确的输出
在控制台输入:f`123${'abc'}`
输出结果:(2) ["123", "", raw: Array(2)] "abc" >>>一个包含"123",""的长度为2的数组,并在后面输出abc
在控制台输入:f`123${'abc'}${'def'}`
输出结果:(3) ["123", "", "", raw: Array(3)] "abc" "qwe" >>>一个包含"123","",""的长度为2的数组,并在后面输出abc,cdf结合两次输出结果,可以发现它总是把${}里面的东西转换成""和正常的字符串放在一个数组里面,并在后面单独输出每个${}的值
在控制台输入:f`1+2=${1+2}${[1,2,3,4]}`
输出结果:(3) ["1+2=", "", "", raw: Array(3)] 3 (4) [1, 2, 3, 4] 现在足以证明只要被${}括起来都会转换成""放在一个数组里面,并且在后面输入${}里面的值
我们再来看一个测试:
//在浏览器控制台输入
//使用rest参数,当你传入的参数是一个函数的话就执行这个函数,其他类型一概不执行
const testTemplate = (...args) => args.forEach(arg => {
if (typeof arg === 'function'){
arg();
}
})
上面定义了一个函数,接下来我们来传参数并且看结果了来测试模版字符串的精髓所在。
在控制台输入:testTemplate(1,2)
输出结果:undefined >>>意料之中,因为当你传入的参数是一个函数的话就执行这个函数,其他类型一概不执行。
在控制台输入:testTemplate(1,() => {consolo.log('执行了')})
输出结果: 执行了 >>>这里打印出‘执行了’,说明后面的函数被执行到
在控制台输入:testTemplate`1,() => {console.log('执行了')}`
输出结果: 执行了 >>>跟上面加了括号的结果一样。
所以styled.h1,styled.div等等其实都是一个函数,它们接受模版字符串这样的参数,而为了实现根据传入的props值显示不同样式,可以这样定义:
const MyDiv = styled.div`
color:${props => props.color};
font-size:${props => props.bigger ? '2em' : '1em'}
`
使用时,可以这样写:
//bigger={true} 也可以省略{true},直接写 bigger
<MyDiv color="green" bigger={true}>something in div...</MyDiv>
总结:
styled-components其实就是函数传递。
React:styled-components的更多相关文章
- styled components草根中文版文档
1.styled components官网网址 https://www.styled-components.com/docs 以组件的形式来写样式. 1.1安装 yarn add styled-c ...
- React & styled component
React & styled component https://www.styled-components.com/#your-first-styled-component tagged t ...
- [React] Use React.ReactNode for the children prop in React TypeScript components and Render Props
Because @types/react has to expose all its internal types, there can be a lot of confusion over how ...
- (翻译)React Container Components
原文:Container Components Container Components 在 React 模式上对我的代码有最深远影响的一个模式叫 container component 模式. 在 ...
- React组件Components的两种表示方式
函数式的表示: function Welcome(props) { return <h1>Hello, {props.name}</h1>; } Class式的表示: clas ...
- 6周学习计划,攻克JavaScript难关(React/Redux/ES6 etc.)
作者:余博伦链接:https://zhuanlan.zhihu.com/p/23412169来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 和大家一样,最近我也看了Jo ...
- 推荐 9 个样式化组件的 React UI 库
简评:喜欢 CSS in JS 吗?本文将介绍一些使用样式组件所构建的 React UI 库,相信你会很感兴趣的. 在 React 社区,对 UI 组件进行样式化的讨论逐步从 CSS 模块到内联 CS ...
- The Road to learn React书籍学习笔记(第一章)
react灵活的生态圈 Small Application Boilerplate: create-react-app Utility: JavaScript ES6 and beyond Styli ...
- Angular Vue React 框架中的 CSS
框架中的 CSS Angular Vue React 三大框架 Angular Vue 内置样式集成 React 一些业界实践 Angular Angular . js (1.x):没有样式集成能力 ...
- (转)2019年 React 新手学习指南 – 从 React 学习线路图说开去
原文:https://www.html.cn/archives/10111 注:本文根据 React 开发者学习线路图(2018) 结构编写了很多新手如何学习 React 的建议.2019 年有标题党 ...
随机推荐
- jq鼠标移入和移出事件
前几天帮朋友做了一个单页面,其中有个效果就是鼠标移动到头像上变换头像样式,当鼠标移出时恢复头像样式.当时没多想,脑子就蹦出了mouseover,mouseout两个方法. 但是在编写页面的过程中,无论 ...
- LInux文件基础知识和文件目录操作(系统调用函数方式)
1.进程是处于活动状态的程序,某个用户通过操作系统运行程序所产生的进程代表着该用户的行为.如果用户不具备访问某个目录和文件的权限,那么该用户的进程也不能访问. 2.Linux系统中文件安全机制是通过给 ...
- ProcessFun
#pragma once #ifndef __PROCESSFUN_H__ #define __PROCESSFUN_H__ #include <iostream> #include &l ...
- CSS:CSS 尺寸 (Dimension)
ylbtech-CSS:CSS 尺寸 (Dimension) 1.返回顶部 1. CSS 尺寸 (Dimension) CSS 尺寸 (Dimension) 属性允许你控制元素的高度和宽度.同样,它允 ...
- delphi基础篇之数据类型
Object Pascal 数据类型 数据类型与定义变量 Object Pascal 语言的最大特点是对数据类型的要求非常严谨.传递给过程或函数的参数值必须与形参的类型一致.在Object ...
- Django框架(六)—— 视图层:HttpRequest、HTTPResponse、JsonResponse、CBV和FBV、文件上传
目录 视图层 一.视图函数 二.视图层之HttpRequest对象 三.视图层之HttpResponse对象 四.视图层之JsonResponse对象 五.CBV和FBV 六.文件上传 视图层 一.视 ...
- socket API CSocket CAsyncSocket 用法及区别
要进行网络编程就要和Socket打交道,Socket有同步阻塞方式和异步非阻塞方式两种使用,事实上同步和异步在我们编程的生涯中可能遇到了很多,而Socket也没什么特别.虽然同步好用,不费劲,但不能满 ...
- UI自动化ADB出现devices offline的解决方法
终端运行如下命令即可解决: adb kill-server adb start-server adb remount
- Quartz CronTrigger 整配置说明
Quartz cron 表达式的格式向下支持到秒级别的计划,而 UNIX cron 计划仅支持至分钟级. Quartz用cron 表达式存放执行计划,引用了cron表达式的CronTrigger在计 ...
- Straight Master (贪心)
题目如下:A straight is a poker hand containing five cards of sequential rank, not necessarily to be the ...