Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/425.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript Vue js在表中插入链接_Javascript_Vuejs2 - Fatal编程技术网

Javascript Vue js在表中插入链接

Javascript Vue js在表中插入链接,javascript,vuejs2,Javascript,Vuejs2,我想在一个表中显示三个不同的json列表。第一个包含URL,第二个指向谷歌地图的URL和最后一条消息 要渲染它,我有如下模板: <script type="text/x-template" id="grid-template"> <table class="table"> <thead> <tr> <th v-for="key in columns" @click="sortBy(k

我想在一个表中显示三个不同的json列表。第一个包含URL,第二个指向谷歌地图的URL和最后一条消息

要渲染它,我有如下模板:

<script type="text/x-template" id="grid-template">
  <table class="table">
    <thead>
      <tr>
        <th v-for="key in columns"
          @click="sortBy(key)"
          :class="{ active: sortKey == key }">
            ${ key | capitalize }
          <span class="arrow" :class="sortOrders[key] > 0 ? 'asc' : 'dsc'">
          </span>
        </th>
      </tr>
    </thead>
    <tbody>
      <tr v-for="entry in filteredData">
        <td v-for="key in columns">${isUrl(key,entry[key])}</td>
      </tr>
    </tbody>
  </table>
</script>


  Vue.component('demo-grid', {
    template: '#grid-template',
    delimiters: ['${', '}'],
    props: {
      data: Array,
      columns: Array,
      filterKey: String
    },
    data: function () {
      var sortOrders = {}
      this.columns.forEach(function (key) {
        sortOrders[key] = 1
      })
      return {
        sortKey: '',
        sortOrders: sortOrders
      }
    },
    computed: {
      filteredData: function () {
        var sortKey = this.sortKey
        var filterKey = this.filterKey && this.filterKey.toLowerCase()
        var order = this.sortOrders[sortKey] || 1
        var data = this.data
        if (filterKey) {
          data = data.filter(function (row) {
            return Object.keys(row).some(function (key) {
              return String(row[key]).toLowerCase().indexOf(filterKey) > -1
            })
          })
        }
        if (sortKey) {
          data = data.slice().sort(function (a, b) {
            a = a[sortKey]
            b = b[sortKey]
            return (a === b ? 0 : a > b ? 1 : -1) * order
          })
        }
        return data
      }
    },
    filters: {
      capitalize: function (str) {
        return str.charAt(0).toUpperCase() + str.slice(1)
      }
    },
    methods: {
      sortBy: function (key) {
        this.sortKey = key
        this.sortOrders[key] = this.sortOrders[key] * -1
      },

      isUrl: function (key, str){
        if (key == "url"){
          var exp = /^((?:https?|ftp):\/\/.)?(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-z]{2,4}\b([-a-zA-Z0-9@:%_\+.~#?&//=]*)/ig;
          return str.replace(exp,"<a :href='$1'>$1</a>");
        }
        else{
          console.log("ej")
          return str
        }
      }
    }

  })

您可以在模板中设置url格式,如下所示:

<tr v-for="entry in filteredData">
  <td v-for="key in columns">
    <template v-if="key === 'url'">
      <a :href="entry[key]">${ entry[key] }</a>
    </template>
    <template v-else>
      ${ entry[key] }
    </template>
  </td>
</tr>

${entry[key]}

您可以在模板中设置url格式,如下所示:

<tr v-for="entry in filteredData">
  <td v-for="key in columns">
    <template v-if="key === 'url'">
      <a :href="entry[key]">${ entry[key] }</a>
    </template>
    <template v-else>
      ${ entry[key] }
    </template>
  </td>
</tr>

${entry[key]}

没有想到这一点。这么简单。。。非常感谢。我没想到。这么简单。。。非常感谢。