%PDF- %PDF-
Direktori : /home/ugotscom/3vfm3/node_modules/vuejs-datatable/docs/tutorials/ajax/ |
Current File : /home/ugotscom/3vfm3/node_modules/vuejs-datatable/docs/tutorials/ajax/ajax-data.html |
<!doctype html> <html class="default no-js"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>Ajax table (via <code>data</code> function) | vuejs-datatable</title> <meta name="description" content=""> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="stylesheet" href="../../assets/css/main.css"> </head> <body> <header> <div class="tsd-page-toolbar"> <div class="container"> <div class="table-wrap"> <div class="table-cell" id="tsd-search" data-index="../../assets/js/search.js" data-base="../.."> <div class="field"> <label for="tsd-search-field" class="tsd-widget search no-caption">Search</label> <input id="tsd-search-field" type="text" /> </div> <ul class="results"> <li class="state loading">Preparing search index...</li> <li class="state failure">The search index is not available</li> </ul> <a href="../../index.html" class="title">vuejs-datatable</a> </div> <div class="table-cell" id="tsd-widgets"> <div id="tsd-filter"> <a href="#" class="tsd-widget options no-caption" data-toggle="options">Options</a> <div class="tsd-filter-group"> <div class="tsd-select" id="tsd-filter-visibility"> <span class="tsd-select-label">All</span> <ul class="tsd-select-list"> <li data-value="public">Public</li> <li data-value="protected">Public/Protected</li> <li data-value="private" class="selected">All</li> </ul> </div> <input type="checkbox" id="tsd-filter-inherited" checked /> <label class="tsd-widget" for="tsd-filter-inherited">Inherited</label> <input type="checkbox" id="tsd-filter-externals" checked /> <label class="tsd-widget" for="tsd-filter-externals">Externals</label> <input type="checkbox" id="tsd-filter-only-exported" /> <label class="tsd-widget" for="tsd-filter-only-exported">Only exported</label> </div> </div> <a href="#" class="tsd-widget menu no-caption" data-toggle="menu">Menu</a> </div> </div> </div> </div> <div class="tsd-page-title"> <div class="container"> <ul class="tsd-breadcrumb"> </ul> <h1> Ajax table (via <code>data</code> function)</h1> </div> </div> </header> <div class="container container-main"> <div class="row"> <div class="col-8 col-content"> <div class="tsd-panel tsd-typography"> <a href="#introduction" id="introduction" style="color: inherit; text-decoration: none;"> <h2>Introduction</h2> </a> <p>You can customize a single <a href="../../classes/vuedatatable.html">VueDatatable</a> by providing a <em>data function</em> instead of the normal array of objects. This function should be a valid <a href="../../globals.html#tdatafn">TDataFn</a>.</p> <div class="alert alert-info"> <i class="fas fa-info-circle"></i> If you want to customize the behavior of <b>multiple tables</b>, you may want to check how to <a href="./ajax-handler.html">use custom handlers</a>. You may also want to <a href="./limit-rows-processing.html">debounce your data processing</a> to avoid requests spamming. </div> <a href="#demo" id="demo" style="color: inherit; text-decoration: none;"> <h2>Demo</h2> </a> <div id="demo-app" class="tutorial-ajax-data"><div class="row"><div class="col-xs-12 table-responsive"><datatable :columns="columns" :data="getData"></datatable><datatable-pager v-model="page"></datatable-pager></div></div></div> <a href="#code" id="code" style="color: inherit; text-decoration: none;"> <h2>Code</h2> </a> <a href="#typescript" id="typescript" style="color: inherit; text-decoration: none;"> <h3>Typescript</h3> </a> <pre><code class="language-ts"><span class="hljs-keyword">import</span> axios <span class="hljs-keyword">from</span> <span class="hljs-string">'axios'</span>; <span class="hljs-keyword">import</span> Vue <span class="hljs-keyword">from</span> <span class="hljs-string">'vue'</span>; <span class="hljs-keyword">import</span> { IDataFnParams, ITableContentParam, TColumnsDefinition } <span class="hljs-keyword">from</span> <span class="hljs-string">'vuejs-datatable'</span>; <span class="hljs-keyword">import</span> { colFieldToStr, formatUtcDate, ISpaceXLaunch, makeQueryStringFromObj } <span class="hljs-keyword">from</span> <span class="hljs-string">'../utils'</span>; <span class="hljs-keyword">const</span> API_URL = <span class="hljs-string">'https://api.spacexdata.com/v3/launches/upcoming'</span>; <span class="hljs-keyword">const</span> app = <span class="hljs-keyword">new</span> Vue( { el: <span class="hljs-string">'#demo-app'</span>, data: { columns: [ { label: <span class="hljs-string">'Flight number'</span>, field: <span class="hljs-string">'flight_number'</span> }, { label: <span class="hljs-string">'Mission name'</span>, field: <span class="hljs-string">'mission_name'</span> }, { label: <span class="hljs-string">'Launch date'</span>, field: <span class="hljs-string">'launch_date_utc'</span>, representedAs: <span class="hljs-function"><span class="hljs-params">row</span> =></span> formatUtcDate( <span class="hljs-keyword">new</span> <span class="hljs-built_in">Date</span>( row.launch_date_utc ) ) }, { label: <span class="hljs-string">'Rocket type'</span>, field: <span class="hljs-string">'rocket.rocket_name'</span>, sortable: <span class="hljs-literal">false</span> }, { label: <span class="hljs-string">'Launch site'</span>, field: <span class="hljs-string">'launch_site.site_name_long'</span>, sortable: <span class="hljs-literal">false</span> }, { field: <span class="hljs-string">'links.mission_patch_small'</span>, interpolate: <span class="hljs-literal">true</span>, label: <span class="hljs-string">'Mission patch'</span>, representedAs: <span class="hljs-function"><span class="hljs-params">row</span> =></span> row.links.mission_patch_small ? <span class="hljs-string">`<img src="<span class="hljs-subst">${ row.links.mission_patch_small }</span>" alt="<span class="hljs-subst">${ row.mission_name }</span> patch" style="height: 6em;"/>`</span> : <span class="hljs-string">`<img src="https://www.gvmc.gov.in/wss/images/noimageavailable.png" alt="No patch for mission &quot;<span class="hljs-subst">${ row.mission_name }</span>&quot; available" style="height: 6em;"/>`</span>, sortable: <span class="hljs-literal">false</span>, }, { field: <span class="hljs-string">'links.reddit_campaign'</span>, interpolate: <span class="hljs-literal">true</span>, label: <span class="hljs-string">'Reddit link'</span>, representedAs: <span class="hljs-function"><span class="hljs-params">row</span> =></span> <span class="hljs-string">`<a href="<span class="hljs-subst">${ row.links.reddit_campaign }</span>"><span class="hljs-subst">${ row.mission_name }</span> Reddit thread</a>`</span>, sortable: <span class="hljs-literal">false</span>, }, ] <span class="hljs-keyword">as</span> TColumnsDefinition<ISpaceXLaunch>, page: <span class="hljs-number">1</span>, <span class="hljs-keyword">async</span> getData( { sortBy, sortDir, perPage, page }: IDataFnParams<ISpaceXLaunch> ) { <span class="hljs-keyword">const</span> sortParams = sortBy && sortDir ? { order: sortDir, sort: colFieldToStr( sortBy ).replace( <span class="hljs-regexp">/\./g</span>, <span class="hljs-string">'/'</span> ), } : {}; <span class="hljs-keyword">const</span> params = { <span class="hljs-comment">// Sorting</span> ...sortParams, <span class="hljs-comment">// Filtering</span> <span class="hljs-comment">// See https://documenter.getpostman.com/view/2025350/RWaEzAiG#json-field-masking</span> filter: <span class="hljs-keyword">this</span>.columns.map( <span class="hljs-function"><span class="hljs-params">col</span> =></span> colFieldToStr( col.field! ).replace( <span class="hljs-regexp">/\./g</span>, <span class="hljs-string">'/'</span> ) ).join( <span class="hljs-string">','</span> ), <span class="hljs-comment">// Paging</span> limit: perPage || <span class="hljs-number">10</span>, offset: ( ( page - <span class="hljs-number">1</span> ) * perPage ) || <span class="hljs-number">0</span>, }; <span class="hljs-keyword">const</span> url = <span class="hljs-string">`<span class="hljs-subst">${ API_URL }</span>?<span class="hljs-subst">${ makeQueryStringFromObj( params ) }</span>`</span>; <span class="hljs-keyword">const</span> { <span class="hljs-comment">// Data to display</span> data, <span class="hljs-comment">// Get the total number of matched items</span> headers: { <span class="hljs-string">'spacex-api-count'</span>: totalCount }, } = <span class="hljs-keyword">await</span> axios.get( url ); <span class="hljs-keyword">return</span> { rows: data, totalRowCount: totalCount, } <span class="hljs-keyword">as</span> ITableContentParam<ISpaceXLaunch>; }, }, } ); </code></pre> <a href="#html" id="html" style="color: inherit; text-decoration: none;"> <h3>HTML</h3> </a> <pre><code class="language-html"><span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">id</span>=<span class="hljs-string">"demo-app"</span>></span> <span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"row"</span>></span> <span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"col-xs-12 table-responsive"</span>></span> <span class="hljs-tag"><<span class="hljs-name">datatable</span> <span class="hljs-attr">:columns</span>=<span class="hljs-string">"columns"</span> <span class="hljs-attr">:data</span>=<span class="hljs-string">"getData"</span>></span><span class="hljs-tag"></<span class="hljs-name">datatable</span>></span> <span class="hljs-tag"><<span class="hljs-name">datatable-pager</span> <span class="hljs-attr">v-model</span>=<span class="hljs-string">"page"</span>></span><span class="hljs-tag"></<span class="hljs-name">datatable-pager</span>></span> <span class="hljs-tag"></<span class="hljs-name">div</span>></span> <span class="hljs-tag"></<span class="hljs-name">div</span>></span> <span class="hljs-tag"></<span class="hljs-name">div</span>></span></code></pre> <script src="https://cdnjs.cloudflare.com/ajax/libs/axios/0.18.0/axios.min.js" integrity="sha256-mpnrJ5DpEZZkwkE1ZgkEQQJW/46CSEh/STrZKOB/qoM=" crossorigin="anonymous" defer></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.6.10/vue.js" crossorigin="anonymous" defer></script> <script src="../../assets/js/vuejs-datatable.js" defer></script> <link rel="stylesheet" href="../../assets/css/additional-styles.css"> <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.8.2/css/all.css" integrity="sha384-oS3vJWv+0UjzBfQzYUhtDYW+Pj2yciDJxpsK1OYPAYjqT085Qq/1cq5FLXAZQ7Ay" crossorigin="anonymous"> <script src="../../assets/js/tutorials/demo-ajax-data.js" defer></script> </div> </div> <div class="col-4 col-menu menu-sticky-wrap menu-highlight"> <nav class="tsd-navigation primary"> <ul> <li class="globals "> <a href="../../globals.html"><em>Globals</em></a> </li> <li class="current "> <a href="../index.html">Tutorial index</a> <ul> <li class=" "> <a href="../bundlers.html">Configuring bundlers & common issues</a> </li> <li class=" "> <a href="../basic.html">Basic table</a> </li> <li class=" "> <a href="../pager-types.html">Pager types</a> </li> <li class="current "> <a href="index.html">Ajax table</a> <ul> <li class=" "> <a href="ajax-handler.html">Ajax table (with handler customization)</a> </li> <li class="current "> <a href="ajax-data.html">Ajax table (via <code>data</code> function)</a> </li> </ul> </li> <li class=" "> <a href="../customize/index.html">Tables customization</a> </li> <li class=" "> <a href="../multiple-tables.html">Multiple tables</a> </li> <li class=" "> <a href="../no-pager.html">No pager</a> </li> <li class=" "> <a href="../limit-rows-processing.html">Limit rows processing</a> </li> </ul> </li> </ul> </nav> <nav class="tsd-navigation secondary menu-sticky"> <ul class="before-current"> </ul> </nav> </div> </div> </div> <footer class="with-border-bottom"> <div class="container"> <h2>Legend</h2> <div class="tsd-legend-group"> <ul class="tsd-legend"> <li class="tsd-kind-module"><span class="tsd-kind-icon">Module</span></li> <li class="tsd-kind-object-literal"><span class="tsd-kind-icon">Object literal</span></li> <li class="tsd-kind-variable"><span class="tsd-kind-icon">Variable</span></li> <li class="tsd-kind-function"><span class="tsd-kind-icon">Function</span></li> <li class="tsd-kind-function tsd-has-type-parameter"><span class="tsd-kind-icon">Function with type parameter</span></li> <li class="tsd-kind-index-signature"><span class="tsd-kind-icon">Index signature</span></li> <li class="tsd-kind-type-alias"><span class="tsd-kind-icon">Type alias</span></li> <li class="tsd-kind-type-alias tsd-has-type-parameter"><span class="tsd-kind-icon">Type alias with type parameter</span></li> </ul> <ul class="tsd-legend"> <li class="tsd-kind-enum"><span class="tsd-kind-icon">Enumeration</span></li> <li class="tsd-kind-enum-member"><span class="tsd-kind-icon">Enumeration member</span></li> <li class="tsd-kind-property tsd-parent-kind-enum"><span class="tsd-kind-icon">Property</span></li> <li class="tsd-kind-method tsd-parent-kind-enum"><span class="tsd-kind-icon">Method</span></li> </ul> <ul class="tsd-legend"> <li class="tsd-kind-interface"><span class="tsd-kind-icon">Interface</span></li> <li class="tsd-kind-interface tsd-has-type-parameter"><span class="tsd-kind-icon">Interface with type parameter</span></li> <li class="tsd-kind-constructor tsd-parent-kind-interface"><span class="tsd-kind-icon">Constructor</span></li> <li class="tsd-kind-property tsd-parent-kind-interface"><span class="tsd-kind-icon">Property</span></li> <li class="tsd-kind-method tsd-parent-kind-interface"><span class="tsd-kind-icon">Method</span></li> <li class="tsd-kind-index-signature tsd-parent-kind-interface"><span class="tsd-kind-icon">Index signature</span></li> </ul> <ul class="tsd-legend"> <li class="tsd-kind-class"><span class="tsd-kind-icon">Class</span></li> <li class="tsd-kind-class tsd-has-type-parameter"><span class="tsd-kind-icon">Class with type parameter</span></li> <li class="tsd-kind-constructor tsd-parent-kind-class"><span class="tsd-kind-icon">Constructor</span></li> <li class="tsd-kind-property tsd-parent-kind-class"><span class="tsd-kind-icon">Property</span></li> <li class="tsd-kind-method tsd-parent-kind-class"><span class="tsd-kind-icon">Method</span></li> <li class="tsd-kind-accessor tsd-parent-kind-class"><span class="tsd-kind-icon">Accessor</span></li> <li class="tsd-kind-index-signature tsd-parent-kind-class"><span class="tsd-kind-icon">Index signature</span></li> </ul> <ul class="tsd-legend"> <li class="tsd-kind-constructor tsd-parent-kind-class tsd-is-inherited"><span class="tsd-kind-icon">Inherited constructor</span></li> <li class="tsd-kind-property tsd-parent-kind-class tsd-is-inherited"><span class="tsd-kind-icon">Inherited property</span></li> <li class="tsd-kind-method tsd-parent-kind-class tsd-is-inherited"><span class="tsd-kind-icon">Inherited method</span></li> <li class="tsd-kind-accessor tsd-parent-kind-class tsd-is-inherited"><span class="tsd-kind-icon">Inherited accessor</span></li> </ul> <ul class="tsd-legend"> <li class="tsd-kind-property tsd-parent-kind-class tsd-is-protected"><span class="tsd-kind-icon">Protected property</span></li> <li class="tsd-kind-method tsd-parent-kind-class tsd-is-protected"><span class="tsd-kind-icon">Protected method</span></li> <li class="tsd-kind-accessor tsd-parent-kind-class tsd-is-protected"><span class="tsd-kind-icon">Protected accessor</span></li> </ul> <ul class="tsd-legend"> <li class="tsd-kind-property tsd-parent-kind-class tsd-is-private"><span class="tsd-kind-icon">Private property</span></li> <li class="tsd-kind-method tsd-parent-kind-class tsd-is-private"><span class="tsd-kind-icon">Private method</span></li> <li class="tsd-kind-accessor tsd-parent-kind-class tsd-is-private"><span class="tsd-kind-icon">Private accessor</span></li> </ul> <ul class="tsd-legend"> <li class="tsd-kind-property tsd-parent-kind-class tsd-is-static"><span class="tsd-kind-icon">Static property</span></li> <li class="tsd-kind-call-signature tsd-parent-kind-class tsd-is-static"><span class="tsd-kind-icon">Static method</span></li> </ul> </div> </div> </footer> <div class="container tsd-generator"> <p>Generated using <a href="https://typedoc.org/" target="_blank">TypeDoc</a></p> </div> <div class="overlay"></div> <script src="../../assets/js/main.js"></script> <script>if (location.protocol == 'file:') document.write('<script src="../../assets/js/search.js"><' + '/script>');</script> </body> </html>