2017-02-02 150 views
1

我有一個Vue.js組件,可以在Firefox,Chrome上正常工作,但Safari和Safari移動瀏覽器會失敗。Vue.js Safari移動版和兼容性

控制檯回報:

Object.values不是一個函數

是否有一個解決這個問題?

完整的代碼如下:

<template> 
<div> 
    <div v-for="(meal, i) in meals"> 
     <div class="panel panel-default"> 
      <div class="panel-body"> 
      <div class="col-sm-3"> 
       <img v-bind:src="all[i].image" class="img-circle" alt="Chicken" width="130px" height="130px"> 
      </div> 
      <div class="col-sm-5"> 
       <div class="col-xs-12"> 
       <h3>{{meal}}</h3> 
       </div> 
      </div> 
      <div class="col-sm-4" id="order_select"> 
       <select v-model="selected" v-model.lazy="creditsPerMeal[meal]" v-on:change="createSelection()"> 
       <option v-for="option in options" v-bind:value="option"> 
        {{ option }} 
       </option> 
       </select> 
      </div> 
      </div> 
     </div> 
    </div> 
    <div class="col-xs-12"> 
     <p>Credits used: {{creditsSum}}/{{credits}}</p> 
    </div> 
    <label>Dietary</label> 
    <input type="textarea" name="dietary" v-model="dietary" class="form-control"> 
    <div class="col-xs-12"> 
     <div id="buy_now"> 
      <p>PRICE: £{{cost}}</p> 
      <form action="/checkout" v-on:submit.prevent="onSubmit" method="post" id="buy_now_form"> 
       <input type="hidden" v-bind:value="select_meal" name="selected_meals" required> 
       <input type="hidden" name="price" v-bind:value="cost"> 
       <input type="submit" value="BUY NOW" class="btn btn-default" :disabled="this.creditsSum != this.credits"> 
      </form> 
     </div> 
    </div> 
    <div class="col-xs-12" v-if="this.credits==='10'"> 
     <div id="subscribe_now"> 
      <p>Subscribe</p> 
       <label>4 Weeks</label> 
       <button type="submit" class="btn btn-default" v-on:click="fourWeek" :disabled="this.creditsSum != this.credits">SUBSCRIBE</button> 
       <label>8 Weeks</label> 
       <button type="submit" class="btn btn-default" v-on:click="eightWeek" :disabled="this.creditsSum != this.credits">SUBSCRIBE</button> 
     </div> 
    </div> 
    <div class="col-xs-12" v-if="this.credits==='12'"> 
     <div id="subscribe_now"> 
      <p>Subscribe</p> 
       <label>4 Weeks</label> 
       <button type="submit" class="btn btn-default" v-on:click="fourWeek" :disabled="this.creditsSum != this.credits">SUBSCRIBE</button> 
       <label>8 Weeks</label> 
       <button type="submit" class="btn btn-default" v-on:click="eightWeek" :disabled="this.creditsSum != this.credits">SUBSCRIBE</button> 
     </div> 
    </div> 
    <div class="col-xs-12" v-if="this.credits==='15'"> 
     <div id="subscribe_now"> 
      <p>Subscribe</p> 
       <label>4 Weeks</label> 
       <button type="submit" class="btn btn-default" v-on:click="fourWeek" :disabled="this.creditsSum != this.credits">SUBSCRIBE</button> 
       <label>8 Weeks</label> 
       <button type="submit" class="btn btn-default" v-on:click="eightWeek" :disabled="this.creditsSum != this.credits">SUBSCRIBE</button> 
     </div> 
    </div> 
</div> 
</template> 

<script> 
import axios from 'axios'; 
    export default { 

    mounted() { 
     console.log('Component ready.'); 

     console.log(JSON.parse(this.f)); 
     console.log(JSON.parse(this.a)); 

    }, 

    props: ['f','c', 'a'], 

    name: 'credits', 
    data: function() { 
    var meals = JSON.parse(this.f) 

    var all = JSON.parse(this.a) 

    var creditsPerMeal = {} 
    for (var i = 0; i < meals.length; i++) { 
     creditsPerMeal[meals[i]] = 0 
    } 

     return { 
     credits: this.c, 
     meals, 
     options: [1,2,3,4,5,6,7,8,9,10], 
     select_meal: [], 
     creditsPerMeal, 
     all, 
     dietary: "", 
     } 
    }, 
    computed: { 
     creditsSum() { 
     return Object.values(this.creditsPerMeal).reduce((a, b) => a + b, 0) 
     }, 

     cost: function() { 
      return this.cost = this.credits * 6; 
     }, 

    }, 
    methods: { 
     onSubmit() { 

      axios.post('/check', { 
        selected_meals: this.select_meal, 
        dietary: this.dietary, 
        price: this.cost 
       }) 
       .then(function(response) { 
        window.location = "/checkout"; 
       }) 
       .catch(function(error) { 
        console.log(error); 
       }); 

     }, 

     createSelection: function(){ 
     this.select_meal = []; 
      for (var i = 0; i < JSON.parse(this.f).length; i++) { 
       this.select_meal.push({ 
        food: JSON.parse(this.f)[i], 
        quantity: this.creditsPerMeal[JSON.parse(this.f)[i]] 
       }); 
      } 
     }, 

     fourWeek: function() { 

     axios.post('/sub', { 
       selected_meals: this.select_meal, 
       package: 4, 
       credits: this.credits 
      }) 
      .then(function(response) { 
       window.location = "/subscribe"; 
      }) 
      .catch(function(error) { 
       console.log(error); 
      }); 

      }, 

      eightWeek: function() { 

      axios.post('/sub', { 
        selected_meals: this.select_meal, 
        package: 8 
       }) 
       .then(function(response) { 
        window.location = "/subscribe"; 
       }) 
       .catch(function(error) { 
        console.log(error); 
       }); 

      }, 


    } 
    } 
</script> 

回答

1

問題在於所有瀏覽器都不支持的Object.values。您可以使用polyfill for Object.values獲得支持。

您可以通過查詢更多信息this website

編輯:

我看到你在代碼中使用import。這使事情變得更容易。

使用npm install object.values

,並在你的代碼開頭使用

import values from 'object.values';

if (!Object.values) { values.shim(); }

+0

感謝這個,我從來沒有使用的填充工具。我已經在https://github.com/es-shims/Object.values添加了提供的代碼到一個文件,並使用腳本標記。這是正確的方式,因爲它不工作。 –

+0

@JamesParsons我已經編輯了我的答案,以便更清楚。希望這對你有用。 – JJJ