%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-handler.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 (with handler customization) | 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 (with handler customization)</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 create a custom <a href="../../classes/tabletype.html">Table Type</a> dedicated to AJAX-sourced data. This approach has the advantage of being totally reuasble, while the <a href="./ajax-data.html">AJAX via data function</a> may be less reuasble across multiple table instances.</p> <p>The example bellow reuses 2 times the same logic, changing only the <code>data</code> parameter to a different endpoint.</p> <div class="alert alert-info"> <i class="fas fa-info-circle"></i> If you want to customize the behavior of your table for a <b>single use</b>, you may want to check the use of <a href="./ajax-data.html">the <code>data</code> function</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-handler"><div class="row"><div class="col-xs-12 table-responsive"><h3>Past launches</h3><ajaxtable :columns="columns" :data="apiUrlPast" name="pastLaunches" :per-page="10"></ajaxtable><datatable-pager table="pastLaunches"></datatable-pager></div><div class="col-xs-12 table-responsive"><h3>Upcoming launches</h3><ajaxtable :columns="columns" :data="apiUrlUpcoming" name="upcomingLaunches" :per-page="10"></ajaxtable><datatable-pager table="upcomingLaunches"></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> { TColumnsDefinition, VuejsDatatableFactory } <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>; VuejsDatatableFactory.registerTableType<<span class="hljs-built_in">any</span>, <span class="hljs-built_in">any</span>, <span class="hljs-built_in">any</span>, <span class="hljs-built_in">any</span>, <span class="hljs-built_in">any</span>>( <span class="hljs-string">'ajaxtable'</span>, <span class="hljs-function"><span class="hljs-params">tableType</span> =></span> tableType .setFilterHandler( <span class="hljs-function">(<span class="hljs-params"> source, filter, columns </span>) =></span> ( { <span class="hljs-comment">// See https://documenter.getpostman.com/view/2025350/RWaEzAiG#json-field-masking</span> filter: 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> ), } ) ) .setSortHandler( <span class="hljs-function">(<span class="hljs-params"> endpointDesc, sortColumn, sortDir </span>) =></span> ( { ...endpointDesc, ...( sortColumn && sortDir ? { order: sortDir, sort: colFieldToStr( sortColumn.field! ).replace( <span class="hljs-regexp">/\./g</span>, <span class="hljs-string">'/'</span> ), } : {} ), } ) ) .setPaginateHandler( <span class="hljs-function">(<span class="hljs-params"> endpointDesc, perPage, pageIndex </span>) =></span> ( { ...endpointDesc, ...( perPage !== <span class="hljs-literal">null</span> ? { limit: perPage || <span class="hljs-number">10</span>, offset: ( ( pageIndex - <span class="hljs-number">1</span> ) * perPage ) || <span class="hljs-number">0</span>, } : {} ), } ) ) <span class="hljs-comment">// Alias our process steps, because the source, here, is our API url, and paged is the complete query string</span> .setDisplayHandler( <span class="hljs-keyword">async</span> ( { source: baseEndPoint, paged: endpointDesc } ) => { <span class="hljs-keyword">const</span> url = <span class="hljs-string">`<span class="hljs-subst">${ baseEndPoint }</span>?<span class="hljs-subst">${ makeQueryStringFromObj( endpointDesc ) }</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<ISpaceXLaunch[]>( url ); <span class="hljs-keyword">return</span> { rows: data, totalRowCount: <span class="hljs-built_in">parseInt</span>( totalCount, <span class="hljs-number">10</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>, apiUrlPast: <span class="hljs-string">'https://api.spacexdata.com/v3/launches/past'</span>, apiUrlUpcoming: <span class="hljs-string">'https://api.spacexdata.com/v3/launches/upcoming'</span>, }, } ); </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">h3</span>></span>Past launches<span class="hljs-tag"></<span class="hljs-name">h3</span>></span> <span class="hljs-tag"><<span class="hljs-name">ajaxtable</span> <span class="hljs-attr">:columns</span>=<span class="hljs-string">"columns"</span> <span class="hljs-attr">:data</span>=<span class="hljs-string">"apiUrlPast"</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"pastLaunches"</span> <span class="hljs-attr">:per-page</span>=<span class="hljs-string">"10"</span>></span><span class="hljs-tag"></<span class="hljs-name">ajaxtable</span>></span> <span class="hljs-tag"><<span class="hljs-name">datatable-pager</span> <span class="hljs-attr">table</span>=<span class="hljs-string">"pastLaunches"</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 class="hljs-attr">class</span>=<span class="hljs-string">"col-xs-12 table-responsive"</span>></span> <span class="hljs-tag"><<span class="hljs-name">h3</span>></span>Upcoming launches<span class="hljs-tag"></<span class="hljs-name">h3</span>></span> <span class="hljs-tag"><<span class="hljs-name">ajaxtable</span> <span class="hljs-attr">:columns</span>=<span class="hljs-string">"columns"</span> <span class="hljs-attr">:data</span>=<span class="hljs-string">"apiUrlUpcoming"</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"upcomingLaunches"</span> <span class="hljs-attr">:per-page</span>=<span class="hljs-string">"10"</span>></span><span class="hljs-tag"></<span class="hljs-name">ajaxtable</span>></span> <span class="hljs-tag"><<span class="hljs-name">datatable-pager</span> <span class="hljs-attr">table</span>=<span class="hljs-string">"upcomingLaunches"</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-handler.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="current "> <a href="ajax-handler.html">Ajax table (with handler customization)</a> </li> <li class=" "> <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>