naive-ui/vue3.md
2021-05-26 16:15:10 +08:00

14 KiB
Raw Permalink Blame History

Migrate from V1

General Breaking Changes

  • css

    • css index naive-ui/lib|es/styles/index.css has been removed, do not import it any more!
  • fonts

    • naive-ui/lib|es/styles/fonts/* has been removed, use vfonts
  • icons

    • naive-ui/lib|es/icons/* is deprecated (vue-loader is required).
    • naive-ui/lib|es/icons/* is removed since v2.10.0
    • use xicons instead.
  • n-nimbus-icon is moved to naive-ui/compat/nimbus-icon (vue-loader is required) n-nimbus-icon is removed since v2.10.0

  • n-nimbus-form-card is removed

  • locale & theme on n-config-provider doesn't accept string any more (not it accepts object).

Components

  • form

    • form-item
      • new
        • show-feedback prop
  • affix

    • deprecate
      • target => listen-to
  • alert

  • anchor

    • new
      • show-rail props
      • show-background props
    • deprecate
      • target => listen-to
  • auto-complete

    • break
      • v-model => v-model:value
    • deprecate
      • on-input => on-update:value
    • new
      • on-blur
      • on-focus
  • avatar

  • back-top

    • new
      • show controlled show
      • on-update:show
      • to teleport target
    • deprecate
      • on-show => on-update:show
      • on-hide => on-update:show
      • target => listen-to
  • badge

  • breadcrumb

  • button

  • button-group

  • card

  • cascader

    • break
      • v-model => v-model:value
      • on-load has different usage
      • leaf-only has different meaning
    • new
      • cascade prop
      • show-path prop
      • default-value prop
    • deprecated
      • on-change => on-update:value
  • checkbox

    • checkbox
      • break
        • value only supports string
      • deprecate
        • on-change => on-update:checked
      • new
        • default-checked prop
    • checkbox-group
      • break
        • value only supports string or null
      • deprecate
        • on-change => on-update:value
  • code

  • collapse

    • deprecate
      • on-expanded-names-change => on-update:expanded-names
    • removed
      • v-model => v-model:expanded-names
  • config-consumer (deprecated)

  • config-provider

    • break
      • theme use new theme from naive export
      • $NOs.theme => useOsTheme
      • theme => legacy-theme
    • deprecate
      • as => tag
      • styleScheme won't working in next version
    • new
      • date-locale prop
      • locale prop
      • provide useOsTheme hook
  • confirm => dialog

    • break
      • rename confirm to dialog
    • remove
      • $NConfirm, $NModal => useDialog
  • data-table

    • deprecate
      • on-filters-change => on-update:filters
      • on-sorter-change => on-update:sorter
      • on-checked-row-keys-change => on-update:checked-row-keys
      • on-page-change => on-update:page
      • on-page-size-change => on-update:page-size
  • date-picker

    • break
      • v-model => v-model:value
    • deprecate
      • on-change => on-update:value
    • new
      • default-value prop
  • descriptions

  • divider

  • drawer

    • break
      • v-model
    • deprecate
      • on-show => on-update:show
      • on-hide => on-update:show
      • target => to
      • drawer-class => class
      • drawer-style => style
    • new
      • display-directive prop
  • dropdown

    • break
      • option.value => option.key
      • item must have unique key
      • submenu must have unique key
    • remove
      • submenu-width
      • submenu-min-width
      • submenu-max-width
    • new
      • option.icon
  • dynamic-input

    • break
      • v-model => v-model:value
      • on-clear is removed
    • deprecate
      • on-input => on-update:value
    • new
      • item-style prop
      • min prop
      • default-value prop
  • dynamic-tags

    • break
      • v-model => v-model:value
  • element

  • empty

  • gradient-text

  • grid

  • icon

  • input

    • break
      • v-model => v-model:value
    • new
      • on-update:value prop
      • default-value prop
  • input-group

  • input-group-label

  • input-number

    • deprecate
      • on-change => on-update:value
    • new
      • default-value prop
  • layout

    • layout-content, layout
      • breaking use-native-scrollbar => native-scrollbar
    • layout-sider
      • breaking use-native-scrollbar => native-scrollbar
      • deprecate
        • on-expand => on-update:collapsed
        • on-collapse => on-update:collapsed
  • list

  • loading-bar

    • remove
      • $NLoadingBar
    • new
      • useLoadingBar
      • n-loading-bar-provider
  • log

    • deprecate
      • scrollToTop => scrollTo
      • scrollToBottom => scrollTo
  • menu

    • deprecate
      • on-expanded-names-change => on-update:expanded-keys
      • on-select => on-update:value
      • expanded-names => expanded-keys
      • default-expanded-names => default-expanded-keys
      • item.name => item.key
    • remove
      • item.titleExtra
      • overlay-width
      • overlay-min-width
  • message

    • rewrite message using n-message-provider
    • new
      • useMessage
    • deprecate
      • onHide => onLeave
      • onAfterHide => onAfterLeave
    • remove
      • message.hide => message.destroy
  • modal

    • rewrite with teleport
    • new
      • display-directive
    • deprecate
      • v-model
      • on-show => on-update:show
      • on-hide => on-update:show
      • overlay-style => style
    • remove
      • default hide behavior for preset
  • notification

    • new
      • useNotification
    • deprecate
      • open => create
      • onHide => onLeave
      • onAfterShow => onAfterEnter
      • onAfterHide => onAfterHide
  • pagination

    • deprecate
      • on-change => on-update:page
      • on-page-size-change => on-update:page-size
  • popconfirm

  • popover

    • new
      • default-show
      • overlap
    • deprecate
      • #activator => #trigger
      • overlay-xxx => body-xxx
    • remove
      • controller
      • max-width
      • width
      • min-width
      • manual trigger is removed, use show to controll the popover
      • body-class, use class instead
      • body-style, use style instead
  • popselect

    • break
      • v-model => v-model:value
    • deprecate
      • on-change => on-update:value
  • progress

  • radio

    • radio-group
      • break
        • default size 'small' => 'medium'
        • value only supports string or null
      • deprecate
        • on-change => on-update:value
    • radio & radio-button
      • break
        • value only supports string
        • checked-value => checked
          • It is change to conform html standard usage
        • on-change => on-update:checked
          • on-change is now a native event
  • result

  • scrollbar

  • select

    • break
      • v-model => v-model:value
      • on-scroll(event, container, content) => on-scroll(event)
      • option.render(h, data) => option.render(data)
    • deprecated
      • on-change => on-update:value
  • slider

  • space

  • spin

    • breaking
      • 'in-small', 'in-medium' and 'in-large' size are removed
    • deprecate
      • spinning => show
  • statistic

  • steps

  • switch

    • remove
      • value => value
      • change => on-update:value
  • table

  • tabs

    • deprecate
      • active-name => value
      • on-active-name-change => on-update:value
  • tag

    • break
      • v-model => v-model:value
    • deprecate
      • on-checked-change => on-update:checked
  • thing

  • time

    • break
      • type default from 'relative' to 'date-time'
  • time-picker

    • break
      • v-model => v-model:value
  • timeline

  • tooltip

    • deprecate
      • #activator => #trigger
  • transfer

    • break
      • v-model => v-model:value
    • deprecate
      • on-change => on-update:value
    • new
      • default-value prop
  • tree

    • break
      • v-model => v-model:selected-keys
    • deprecate
      • on-selected-keys-change => on-update:selected-keys
      • on-checked-keys-change => on-update:checked-keys
      • on-expanded-keys-change => on-update:expanded-keys
  • typography

    • breaking
      • text, p
        • depth from primary ... tertiary => 1, 2, 3
    • deprecate
      • text
        • as => tag
  • upload

  • nimbus-service-layout

    • breaking
      • v-model => v-model:value
  • TODO

    • vooks
    • icons from vicons
    • fonts from vfonts
    • vite-build
    • rollup-build
    • tusimple theme
    • clean delegate
    • site production tag (bug)
    • demo scrollbar 的问题
    • table x scroll 右侧阴影不消失
    • log scrollTo 有点问题
    • remove hollowoutable
    • styleScheme, css variables 组件
      • 文档之后再说
    • use-global-style ? 感觉效果不会特别好而且还是很无谓的性能开销这个问题可以之后再思考,现阶段 vue 的写法还是全局 install
    • dynamic-input, no value
    • button, input 的 css 变量名需要修改一下
    • test rollup treeshaking
    • test webpack treeshaking
    • menu utils render
    • dialog bug
    • data-table css vars
    • typography css vars
    • spin css vars
    • radio css vars
    • checkbox css vars
    • avatar css vars
    • landing page icon
    • switch styles
    • slider styles
    • drawer api
    • chrome date-picker overflow (focus({ preventScroll }))
    • slider 键盘好像会激活不该激活的 tooltip...
    • transfer 打包之后有问题
    • side effects = false 好像会影响 rollup 的打包(这让我很不安,要是生效 css 怎么办?要是不生效 JS 怎么办?)(事实上确实会影响网站对于 fonts 的打包,只能先靠脚本凑活一下) https://github.com/rollup/plugins/issues/692
    • vue 在 $attrs 的处理上 dev 和 prod 还是有差别 https://github.com/vuejs/vue-next/issues/2741
    • date-picker input 的 clear 有时候不会清除,看起来是 vue 的 bug
    • radio-group 影响主题切换,看起来是 vue 的 bug
    • cascader demo async 切换未重置数据demo 写的有问题
    • gradient-text transition 又没了
    • md-loader code
    • input + form-item style
    • loadingbar theme
    • dropdown group + menu use dropdown
    • 多行 message
    • progress height
    • close 重构
    • data-table, radio style 重构
    • message icon style
    • transfer search icon style
    • base selection icon style
    • date picker not working
    • avatar font size bug
    • handle global style
      • 暂时放在 useTheme + useStyle 中... 似乎没啥太好的办法,最终还是要想办法让样式不要溢出
    • select menu padding top & bottom
    • time-picker invalid
    • date-picker invalid
    • vooks useNow
    • treemate activePath includeGroup: false
    • 拆分 dateFns locale => dateLocale
    • 试图把组件的 demo 放到 src 里面
    • 去掉仅存的 mixin
    • form item default type explain
    • selection focus style
    • refactor site use store!!! singleton
    • 文档网站主题切换
    • 文档网站 demo 样式
    • anchor bug
    • getKey select & autocomplete type safe & input event interface? onInput value | null or value
    • vshow (maybe create a vue pr)
    • jsx focusin out (waiting for vue update)
    • inject key & value in type (I should use InjectionKey...)
    • form item no label css
    • unify treemate ignored
    • fix menu extra
    • build icon
    • compat
    • fix upload dragger
    • fix table sorter
    • tree 多选节点第二个 demo
    • table treemate!!!
    • createTheme
    • build site
    • table fixed col
    • prefixCls暂时不需要
    • 更新一波文档 props
    • 更新样式的文档
    • on update value api
    • anchor in modal page, maybe a bug of vue...
    • menu + dropdown collapsed 时候 menu item 不更新selected 从使用 useMemo 切换成 computed性能下降, Vue 在这种时候一定存在 bug但是暂时没空找了...
    • select menu multiple, when show=true, checkmark transiton not working推测是 vue 的 bug
    • demo hmr (或许是 vite-plugin-vue 或 vite 的 bug修改内容不更新
    • 不再提前编译 demo 的 highlight code应该可以缩小很多打包体积
    • fix input textarea clear...
    • input auto size
    • data table custom render sorter
    • upload retry
    • table bottom-bordered
    • data table filter menu
    • popover default trigger
    • select option type
    • popover after enter 之后关闭再生效 把 duration 和 delay 弄小点,而且里面事件处理器其实写的有问题
    • popover width
    • selection popover 滚动
    • card 设定高度
    • dropdown 手动定位有 bugmousemoveoutside
    • select menu loading
    • refactor layout to make position work on first shot
    • mention mention pending option not correct, sometimes it is not the first option In fact it's caused by mouse hover on item...
    • code Deprecated as of 10.7.0. highlight(lang, code, ...args) has been deprecated.
    • vdirs zindexable https://github.com/vuejs/vue-next/issues/3497
    • collapse-item overflow
    • anchor ignore gap 有 bug
    • popover click 移动端不生效
    • menu path 对应的问题
    • debug anchor 删除无用 link
    • popover inst methods
    • ios 浏览器 demo code font size 不对
    • table overflow bordered
    • table ellipisis vertical align
    • form item grid item
    • select filter composite...
    • 清理导出的 select 类型
    • make eslint work with markdown ts

Build

package: tsx => es|lib => terse cssr => replace global vars => release

site: build package => move to node_modules => setup side effects => vite build => release

Info

https://github.com/vuejs/vue-next/issues/2549 last cherry-picked commit: 6560ae34d71b81d584af79f810cb9dfa87119d1a