最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to change day-format (M > Mo, F > Fr...) in Datemonth pickers of Vuetify - Stack Overflow

programmeradmin1浏览0评论

I try to change format of days in Date/month picker ponent. At the moment list of days as "M,T,W,T,F,S,S", but I need "Mo,Tu,We,Th,Fr,Sa,Su". In API I can see that necessary parameter called "day-format" and its value is null (default). Can anybody please explain: is it possible to change this format of days?

Here is the API of Vuetify:

I try to change format of days in Date/month picker ponent. At the moment list of days as "M,T,W,T,F,S,S", but I need "Mo,Tu,We,Th,Fr,Sa,Su". In API I can see that necessary parameter called "day-format" and its value is null (default). Can anybody please explain: is it possible to change this format of days?

Here is the API of Vuetify: https://vuetifyjs./en/ponents/date-pickers#date-month-pickers

Share Improve this question edited Aug 20, 2019 at 16:22 Daniel 35.8k17 gold badges114 silver badges161 bronze badges asked Aug 20, 2019 at 16:19 ZmagarochakZmagarochak 3731 gold badge3 silver badges9 bronze badges
Add a ment  | 

3 Answers 3

Reset to default 3
  • Use the weekday-format to pass the date to a function;
  • Convert the date to day of the week (0..6)
  • Use that as the index for an array of strings ('Mo'..'Su')

code:

<div id="app">
  <v-app id="inspire">
    <v-row justify="center">
      <v-date-picker :weekday-format="getDay" v-model="picker"></v-date-picker>
    </v-row>
  </v-app>
</div>
const daysOfWeek = ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'];

new Vue({
  el: '#app',
  vuetify: new Vuetify(),
  data () {
    return {
      picker: new Date().toISOString().substr(0, 10),
    }
  },
  methods:{
    getDay(date){
      let i = new Date(date).getDay(date)
      return daysOfWeek[i]
    }
  }
})

Multiple ways to solve for this, but I somewhat reverse-engineered their source to find out more about the properties that's being passed into the weekday-format prop:

  <div>
    <v-calendar
      :weekday-format="formatWeekDay"
    />
  </div>

  const calendar = {
    name: 'Calendar',
    methods: {

      formatWeekDay(props) {
        return new Date(props.date.replace(/-/g, '\/')).toLocaleDateString('en-US', {weekday: 'narrow'});
      }

    }
  };

I took some guidance from this answer to determine the best way to parse the date being provided back. You can read more about how the locale functionality works, here.

Use the first-day-of-week to pass the date to a function

<v-date-picker v-model="date" :first-day-of-week="1">

与本文相关的文章

发布评论

评论列表(0)

  1. 暂无评论