vite-plugin-stylex-jsx-attribute

1.1.0 • Public • Published

vite-plugin-stylex-jsx-attribute

Some recent utility-based styling solutions are extremely terse and easy to write. StyleX chooses to prioritize readability and maintainability over terseness.

stylex 优先考虑的是可读性和可维护性而不是简洁性,所以写起来有点繁琐

function Demo() {
  return (
    <div {...stylex.props(styles.base1)}>
      <div {...stylex.props(styles.base2)}>
        <div {...stylex.props(styles.base3)} />
      </div>
      <div {...stylex.props(styles.base4)} />
    </div>
  )
}

像这样组件代码越来越长后看着就很难受了

本插件在 dom 标签上增加了一个 stylex属性,来代替 {...stylex.props(styles.base3)这种繁琐的写法,具体用法如下:

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react-swc'
import { stylexPlugin } from 'vite-plugin-stylex-dev'
import jsxStylex from 'vite-plugin-stylex-jsx-attribute'

export const defineConfig({
  plugins: [jsxStylex(), react(), stylexPlugin()],
})
import { styles } from './styles'

export default function Test() {
  return (
    <div stylex={[styles.color('#ff0'), styles.hello]}>
      <span stylex={styles.text} />
    </div>
  )
}

如果想把样式写在组件内部可以手动引入 stylex

import * as stylex from '@stylexjs/stylex'; // 只能通过这种方式引入,其他方式报错

const styles = stylex.create({
  base: {
    fontSize: 16,
    lineHeight: 1.5,
    color: 'grey',
  },
  highlighted: {
    color: 'rebeccapurple',
  },
});

export default function Test() {
  return (
    <div stylex={[styles.base]}>
      <span stylex={styles.highlighted} />
    </div>
  )
}

修改tsconfig.json,解决编辑器不认 stylex属性问题

{
  "compilerOptions": {
    "target": "ES2020",
    "useDefineForClassFields": true,
    "lib": ["ES2020", "DOM", "DOM.Iterable"],
    "module": "ESNext",
    "skipLibCheck": true,

    /* Bundler mode */
    "moduleResolution": "bundler",
    "allowImportingTsExtensions": true,
    "resolveJsonModule": true,
    "isolatedModules": true,
    "noEmit": true,
    "jsx": "react-jsx",

    /* Linting */
    "strict": true,
    "noUnusedLocals": true,
    "noUnusedParameters": true,
    "noFallthroughCasesInSwitch": true,
    "baseUrl": "./",
    "paths": {
      "@/*": ["src/*"],
    }
  },
- "include": ["src"],
+ "include": ["src", "./node_modules/vite-plugin-stylex-jsx-attribute/stylex.d.ts"],
  "references": [{ "path": "./tsconfig.node.json" }]
}

或者在vite-env.d.ts中添加

/// <reference types="vite/client" />
/// <reference types="vite-plugin-stylex-jsx-attribute/stylex.d.ts" />

Package Sidebar

Install

npm i vite-plugin-stylex-jsx-attribute

Weekly Downloads

10

Version

1.1.0

License

ISC

Unpacked Size

10.7 kB

Total Files

7

Last publish

Collaborators

  • lf7817