博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linaria 1.0正式发布:一个零运行时CSS-in-JS库
阅读量:6423 次
发布时间:2019-06-23

本文共 1674 字,大约阅读时间需要 5 分钟。

Linaria]()(一个零运行时CSS-in-JS库)第一个稳定版已发布,可供开发人员使用。Linaria提供了一个新的API,可以与React一起使用,目的是提供更好的开发者体验和构建集成。

Linaria在其中新增了styled标签。styled标签使用参数化的样式创建React组件。

import { styled } from 'linaria/react';// Create a styled componentconst Button = styled.a`  display: inline-block;  border-radius: 3px;  padding: 0.5rem 0;  margin: 0.5rem 1rem;  width: 11rem;  background: transparent;  color: white;  border: 2px solid white;`render(    \u0026lt;Button      href=\u0026quot;https://github.com/callstack/linaria\u0026quot;      target=\u0026quot;_blank\u0026quot;      rel=\u0026quot;noopener\u0026quot;      primary    \u0026gt;      GitHub    \u0026lt;/Button\u0026gt;)

Linaria的标签遵循的是。模板字面量是指可以嵌入表达式的字符串。被标记的模板可以使用函数来解析模板字面量。在上面的代码示例中,display: inline-block是一个模板字面量,styled.a是一个模板标签,styled.adisplay: inline-block是一个被标记的模板字面量。开发人员可以使用标准CSS语法或编写模板字面量。

此外,styled标签通过在模板字面量内插入函数来。

const Title = styled.h1`  color: ${props =\u0026gt; (props.primary ? 'tomato' : 'black')};`;

React组件Title将根据primary属性将颜色调整为tomato或black。

不过,IE等较老的浏览器不支持动态样式,因为动态样式依赖CSS自定义属性(也称为)。现代浏览器可以支持CSS自定义属性。

Linaria 1.0附带了一个新的(CLI),用于从JavaScript中提取CSS内容。下面的命令将从component和screen目录提取CSS,并放进styles目录中。

npx linaria -o styles src/component/**/*.js src/screens/**/*.js

Linaria 1.0还提供了一个新的插件,允许开发人员使用Rollup构建项目,作为Webpack的替代。这个版本还改进了对处理器的支持。虽然以前的Linaria版本只支持,但现在Linaria允许开发人员使用任意的,比如Sass或自定义PostCSS语法。Linaria还可以接受一个配置文件(linaria.config.js)。最重要的是,Linaria支持CSS源映射,带来了简化的调试体验。

CSS-in-Js是指一种在JavaScript而不是外部CSS文件中定义CSS的模式。它有两种子可以共存的子模式。运行时CSS-in-JS库(如Emotion或style-components)可以在运行时动态修改样式,例如将样式标签注入文档。零运行时CSS-in-Js是一种在构建时提取所有CSS的模式。Linaria和Astroturf是这种模式的主要支持者。

Linaria是一个基于MIT许可的开源项目。欢迎读者参与Linaria GitHub项目的贡献,并遵循Linaria行为准则和贡献指南。

查看英文原文

转载地址:http://evgra.baihongyu.com/

你可能感兴趣的文章
mac 删除文件夹里所有的.svn文件
查看>>
程序制作 代写程序 软件定制 代写Assignment 网络IT支持服务
查看>>
mysql 案例~select引起的性能问题
查看>>
直接读取图层
查看>>
springsecurity 源码解读 之 RememberMeAuthenticationFilter
查看>>
HTML5标准学习 - 编码
查看>>
JS 时间戳转星期几 AND js时间戳判断时间几天前
查看>>
UVa11426 最大公约数之和(正版)
查看>>
mime
查看>>
SQL练习之求解填字游戏
查看>>
DOM
查看>>
关于网上商城开发的随笔记录1
查看>>
UIApplication
查看>>
12:Web及MySQL服务异常监测案例
查看>>
hdu 3955 March
查看>>
数据库性能优化之冗余字段的作用
查看>>
C语言程序设计第五次作业
查看>>
Go语言的接口
查看>>
DBA_实践指南系列9_Oracle Erp R12应用补丁AutoPatch/AutoControl/AutoConfig(案例)
查看>>
Python语言学习 (六)1.2
查看>>