繁体   English   中英

VueJS动态更新v-html内容

[英]VueJS dynamically update v-html content

我正在尝试使用JS更新v-html绑定,但似乎有些卡住。 有人可以帮忙吗?

代码的想法是每页列出一个项目。 我想创建一个分页。 分页号代表current_page

问题是我正在尝试更新页码,但似乎无法正常使用。

我已将此添加到jsfilde中

 var configuration = { searchableFields: ['title', 'tags', 'actors'], sortings: { name_asc: { field: 'name', order: 'asc' } }, aggregations: { tags: { title: 'Tags', size: 10 }, actors: { title: 'Actors', size: 10 }, genres: { title: 'Genres', size: 10 } } } // the rows comes from external resources // https://github.com/itemsapi/itemsapi-example-data/blob/master/jsfiddle/imdb.js itemsjs = itemsjs(rows, configuration); var per_page = 3; var current_page = 1; var vm = new Vue({ el: '#el', data: function() { // making it more generic var filters = {}; Object.keys(configuration.aggregations).map(function(v) { filters[v] = []; }) return { query: '', // initializing filters with empty arrays filters: filters, } }, methods: { reset: function() { var filters = {}; Object.keys(configuration.aggregations).map(function(v) { filters[v] = []; }) this.filters = filters; this.query = ''; } }, computed: { searchResult: function() { var result = itemsjs.search({ query: this.query, filters: this.filters, per_page: per_page, page: current_page }) return result } } }); var content = ""; var active = ""; var total = document.getElementById("pagination__total").value; var num_pages = Math.ceil(total / per_page); console.log(num_pages); for (var i = 1; i <= num_pages; i++) { active = current_page == i ? "is-current" : ""; content += `<li class="pagination-link is-size-6 ${active}" data-page="${i}">${i}</li>`; } document.querySelector(".pagination-list").innerHTML = content; content = ""; let pagination = document.querySelectorAll(".pagination-link"); for (let i = 0; i < pagination.length; i++) { pagination[i].addEventListener("click", ev => { current_page = ev.target.getAttribute("data-page"); console.log(current_page); vm.searchResult.page = current_page; }); } 
 <script src="https://cdn.jsdelivr.net/vue/latest/vue.js"></script> <script src="https://cdn.rawgit.com/itemsapi/itemsjs/master/dist/itemsjs.js"></script> <script src="https://code.jquery.com/jquery-1.12.4.min.js"></script> <link href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.0.0/css/bootstrap.min.css" rel="stylesheet"/> <script src="https://cdn.rawgit.com/itemsapi/itemsapi-example-data/master/jsfiddle/imdb.js"></script> <div id="el"> <nav class="navbar navbar-default navbar-fixed-top"> <div class="container"> <div class="navbar-header"> <a class="navbar-brand" href="#" v-on:click="reset()">ItemsJS movies</a> </div> <div id="navbar"> <form class="navbar-form navbar-left"> <div class="form-group"> <input type="text" v-model="query" class="form-control" placeholder="Search"> </div> </form> </div> <!--/.nav-collapse --> </div> </nav> <div class="container" style="margin-top: 50px;"> <input type="hidden" v-bind:value="searchResult.pagination.total" id="pagination__total"> <input type="hidden" v-bind:value="searchResult.pagination.page" id="pagination__curent-page"> <h1>List of items ({{ searchResult.pagination.total }})</h1> <p class="text-muted">Search performed in {{ searchResult.timings.search }} ms, facets in {{ searchResult.timings.facets }} ms</p> <div class="row"> <div class="col-md-2 col-xs-2"> <div v-for="facet in searchResult.data.aggregations"> <h5 style="margin-bottom: 5px;"><strong style="color: #337ab7;" v-html="facet.title"></strong></h5> <ul class="browse-list list-unstyled long-list" style="margin-bottom: 0;"> <li v-for="bucket in facet.buckets"> <div class="checkbox block" style="margin-top: 0; margin-bottom: 0;"> <label> <input class="checkbox" type="checkbox" v-model="filters[facet.name]" v-bind:value="bucket.key"> {{ bucket.key }} ({{ bucket.doc_count }}) </label> </div> </li> </ul> </div> </div> <div class="col-md-10 col-xs-10"> <div class="breadcrumbs"></div> <div class="clearfix"></div> <!--<h3>List of items ({{ searchResult.pagination.total }})</h3>--> <table class="table table-striped"> <tbody> <tr v-for="item of searchResult.data.items"> <td><img style="width: 100px;" v-bind:src="item.image"></td> <td></td> <td> <b v-html="item.name"></b> <br /> </td> <td></td> </tr> </tbody> </table> <div class="clearfix"></div> </div> <nav class="pagination is-centered" aria-label="pagination"> <div> <i class="pagination-previous is-size-6 fas fa-angle-double-left"></i> <ul class="pagination-list"></ul> <i class="pagination-next is-size-6 fas fa-angle-double-right"></i> </div> </nav> <div class="clearfix" style="margin-bottom: 100px;"></div> </div> </div> </div> 

只需将current_page放在data

...
var vm = new Vue({
  data: function() {
    ...
    return {
      query: '',
      current_page,
      filters: filters
    }
  }
  ...
}

然后使用vm.current_page而不是current_page

pagination[i].addEventListener("click", ev => {
  vm.current_page = ev.target.getAttribute("data-page");
  console.log(vm.current_page);
});

searchResult: function() {

  var result = itemsjs.search({
    query: this.query,
    filters: this.filters,
    per_page: per_page,
    page: this.current_page // <-----
  })
  return result
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM