%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/ugotscom/3vfm3/node_modules/vuejs-datatable/docs/tutorials/ajax/
Upload File :
Create Path :
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 &lt;code&gt;data&lt;/code&gt; 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 &lt;code&gt;data&lt;/code&gt; 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> =&gt;</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> =&gt;</span> row.links.mission_patch_small ?
                    <span class="hljs-string">`&lt;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;"/&gt;`</span> :
                    <span class="hljs-string">`&lt;img src="https://www.gvmc.gov.in/wss/images/noimageavailable.png" alt="No patch for mission &amp;quot;<span class="hljs-subst">${ row.mission_name }</span>&amp;quot; available" style="height: 6em;"/&gt;`</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> =&gt;</span> <span class="hljs-string">`&lt;a href="<span class="hljs-subst">${ row.links.reddit_campaign }</span>"&gt;<span class="hljs-subst">${ row.mission_name }</span> Reddit thread&lt;/a&gt;`</span>,
                sortable:      <span class="hljs-literal">false</span>,
            },
        ] <span class="hljs-keyword">as</span> TColumnsDefinition&lt;ISpaceXLaunch&gt;,
        page: <span class="hljs-number">1</span>,
        <span class="hljs-keyword">async</span> getData( { sortBy, sortDir, perPage, page }: IDataFnParams&lt;ISpaceXLaunch&gt; ) {
            <span class="hljs-keyword">const</span> sortParams = sortBy &amp;&amp; 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> =&gt;</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&lt;ISpaceXLaunch&gt;;
        },
    },
} );
</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">&lt;<span class="hljs-name">div</span> <span class="hljs-attr">id</span>=<span class="hljs-string">"demo-app"</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"row"</span>&gt;</span>
        <span class="hljs-tag">&lt;<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"col-xs-12 table-responsive"</span>&gt;</span>
            <span class="hljs-tag">&lt;<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>&gt;</span><span class="hljs-tag">&lt;/<span class="hljs-name">datatable</span>&gt;</span>
            <span class="hljs-tag">&lt;<span class="hljs-name">datatable-pager</span> <span class="hljs-attr">v-model</span>=<span class="hljs-string">"page"</span>&gt;</span><span class="hljs-tag">&lt;/<span class="hljs-name">datatable-pager</span>&gt;</span>
        <span class="hljs-tag">&lt;/<span class="hljs-name">div</span>&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">div</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">div</span>&gt;</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>

Zerion Mini Shell 1.0