<template>
<div id="app">
</div>
</template>
<script>
export default {
name: 'app',
data () {
return {
msg: 'Welcome to Your Vue.js App'
}
},
methods: {
getPost() {
}
}
}
</script>
<style lang="scss">
#app {
font-family: 'Avenir', Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
h1, h2 {
font-weight: normal;
}
ul {
list-style-type: none;
padding: 0;
}
li {
display: inline-block;
margin: 0 10px;
}
a {
color: #42b983;
}
</style>
import Vue from 'vue'
import App from './App.vue'
new Vue({
el: '#app',
render: h => h(App)
})
add_action( 'wp_ajax_btt_ajax', 'btt_ajax' );
add_action( 'wp_ajax_nopriv_btt_ajax', 'btt_ajax' );
function btt_ajax() {
global $wp_query;
if (isset($_POST)) {
$value = $_POST['value'];
query_posts(array_merge(
array(
'meta_value' => $value
),
$wp_query->query));
if(have_posts()) :
while(have_posts()) : the_post();
require 'tpl.php';
endwhile;
endif;
}
wp_die();
}
<div class="filter">
<h3>Выбор категории</h3>
<ul>
<li><a href="#" data-value="">Все категории</a></li>
<li><a href="#" data-value="detali_acess">Аксессуары</a></li>
<li><a href="#" data-value="detali_dvig">Двигатель</a></li>
<li><a href="#" data-value="detali_kuzov_vnutri">Кузов внутри</a></li>
<li><a href="#" data-value="detali_kuzov_snar">Кузов наружные элементы</a></li>
<li><a href="#" data-value="detali_optika">Оптика</a></li>
<li><a href="#" data-value="detali_podveska">Подвеска</a></li>
<li><a href="#" data-value="detali_topliv_sistema">Топливная система</a></li>
<li><a href="#" data-value="detali_tormozn_sistema">Тормазная система</a></li>
<li><a href="#" data-value="detali_transsmis">Трансмиссия</a></li>
<li><a href="#" data-value="detali_elektrika">Электрика</a></li>
<li><a href="#" data-value="detali_kolesa">Колеса</a></li>
</ul>
</div>
$('.filter ul li a').click(function(e) {
e.preventDefault();
var attrFocus = $(this).attr('data-value');
var prodContent = $('.products_list');
$.ajax({
url: '/wp-admin/admin-ajax.php',
type: 'POST',
data: {
value: attrFocus,
action: 'btt_ajax'
},
beforeSend: function() {
prodContent.animate({opacity: '.3'}, 250)
},
success: function(res) {
prodContent.html(res);
prodContent.animate({opacity: '1'}, 250)
},
error: function() {
console.log('error ajax');
}
});
});