رفتن به مطلب

نمایش نتایج جستجو بصورت دلخواه


mehrdad_k

پست های پیشنهاد شده

سلام

من میخوام نتایج جستجو را بصورتی تنظیم کنم که مثلا ده پست دلخواهم  (در صورتی که هر کدام از این ده پست در نتایج جستجو باشند) اول نمایش داده بشه بعد باقی به همون ترتیب پیشفرض (تاریخ). ترتیب نمایش ده پست مهم نیست.

به ذهنم رسید که با زمینه های دلخواه چک باکس ویژه بگذارم براش اما در نتایج جستجو چطور باید ترتیب اونها رو بالاتر نشون بدم ؟

ویرایش شده توسط merhzar_h
لینک به ارسال

دوستان کسی میتونه کمک کنه ؟

میخوام پست های ویژه در صورتی که جزء نتایج جستجو باشند در صدر قرار گیرند.

همچنین دسته. اگر دسته ای باز شد پست های ویژه در صدر باشند سپس باقی پست ها.

لینک به ارسال

می تونید یک زمینه دلخواه بسازید به نام مثلا postorder و مقدارش رو عدد بگذارید که ده پست دلخواهتون اولین اعداد رو داشته باشند و بعد با یک تابع search_query رو ست کنید 

برای نوشتن تابع از این پست کمک بگیرید 

http://forum.wp-parsi.com/topic/37446-چیدمان-محصولات-بر-اساس-نام-در-درسته/?do=findComment&comment=235334

لینک به ارسال
در 17 ساعت قبل، imanfakhar گفته است :
در 17 ساعت قبل، imanfakhar گفته است :

می تونید یک زمینه دلخواه بسازید به نام مثلا postorder و مقدارش رو عدد بگذارید که ده پست دلخواهتون اولین اعداد رو داشته باشند و بعد با یک تابع search_query رو ست کنید 

برای نوشتن تابع از این پست کمک بگیرید 

http://forum.wp-parsi.com/topic/37446-چیدمان-محصولات-بر-اساس-نام-در-درسته/?do=findComment&comment=235334

می تونید یک زمینه دلخواه بسازید به نام مثلا postorder و مقدارش رو عدد بگذارید که ده پست دلخواهتون اولین اعداد رو داشته باشند و بعد با یک تابع search_query رو ست کنید 

برای نوشتن تابع از این پست کمک بگیرید 

http://forum.wp-parsi.com/topic/37446-چیدمان-محصولات-بر-اساس-نام-در-درسته/?do=findComment&comment=235334

ممنون استاد بزگروار از پاسختون

کد زیر رو مستقیم در function.php قرار دادم تغییری در نمایش نتایج دسته ها بوجود نیامد . اگه این دلیلش معلوم بشه میشه رفته سراق کوئری بعدی ..


add_action( 'pre_get_posts', 'foo_modify_query_orderby_title' );
function foo_modify_query_orderby_title( $query ) {
    if ( ! is_admin() && $query->is_main_query() && $query->get( 'cat' ) )
        $query->set( 'orderby', 'title' );
}

در قالب، حلقه بصورت زیر شروع شده:

 while ( have_posts() ) : the_post();

ضمنا برای تست خودم یک کوئری تست کردم و ترتیب نمایش را بر اساس زمینه دلخواه postorder دادم . عدد پیشفرض زمینه دلخواه را 200 قرار دادم و برای بعضی پست ها اعدادی بین 1 تا 10 قرار دادم. سرت به درستی انجام شد ولی مشکل اینه که حتما باید پست ها را یکبار باز کرد و ویرایش کرد تا در نتایج نمایش داده شود. آیا راهی هست که بیشه به کل پست ها بدون ویرایش همه، این فیلد را اختصاص داد؟

از این روش روی لوکال تست کردم تغییری انجام نشد :

function add_custom_field_automatically($post_ID) {
global $wpdb;
if(!wp_is_post_revision($post_ID)) {
    add_post_meta($post_ID, 'postorder', '200', true);
}
}
add_action('publish_page', 'add_custom_field_automatically');
add_action('publish_post', 'add_custom_field_automatically');

 

ویرایش شده توسط merhzar_h
لینک به ارسال
در در 4‏/4‏/2016 at 16:00، imanfakhar گفته است :

می تونید یک زمینه دلخواه بسازید به نام مثلا postorder و مقدارش رو عدد بگذارید که ده پست دلخواهتون اولین اعداد رو داشته باشند و بعد با یک تابع search_query رو ست کنید 

برای نوشتن تابع از این پست کمک بگیرید 

http://forum.wp-parsi.com/topic/37446-چیدمان-محصولات-بر-اساس-نام-در-درسته/?do=findComment&comment=235334

جناب فخار (یا دیگر اساتید) ممکنه بفرمایید مشکل نوشتن این کوئری چطور حل میشه ؟

باتشکر.

لینک به ارسال

اول اینکه ساخت متای اتوماتیک به چه دردتون می خوره رو نمی دونم چونت لازمه متای مورد نظر رو دستی بسازید تا پستهایی که دارای اون مقدار هستند اول نمایش داده بشند  و الا که نیازی به اینکار نیست

دوم اینکه من عرض کردم از کد اون تایپیک برای ساخت تابع استفاده کنید نه اینکه اون تابع رو کپی کنید 

add_action( 'pre_get_posts', 'foo_modify_search_query_custom_orderby' );
function foo_modify_search_query_custom_orderby( $query ) {
    if ( ! is_admin() && $query->is_main_query() && is_search() )
        $query->set( 'meta_key', 'postorder' );
        $query->set( 'orderby', 'meta_value' );
}

 

لینک به ارسال

برای اینکه به کل پستها متا با مقدار دیفالت بدید یک قالب برگه با کدهای زیر بسازید :

<?php
/*template name: update meta*/
$q = new WP_Query(array(
'post_type'	=>	array('post', 'page'),
'post_status'	=>	array('publish'),
'posts_per_page'	=>	'-1',
'order'	=>	'ASC'
));
get_header();
if($q->have_posts()) :
$x =200;
while($q->have_posts()) :
$q->the_post();
update_post_meta($q->post->ID, 'postorder', $x);
echo $q->post->post_title.' Updated <br>';
endwhile;
endif;
wp_reset_query();
get_footer();
?>

بعد از طریق ادمین برگه ای با قالب update meta منتشر کنید و برگه رو باز کنید وقتی نام تمام مطالبتون در صفحه چا\ شد برگه رو ببندید و از وردپرس حذفش کنید قالبی که ساخته اید رو هم پاک کنید

ویرایش شده توسط imanfakhar
لینک به ارسال

اول عرض کنم بسیار عالی بود. واقعا ممنون.

در در 11‏/4‏/2016 at 06:32، imanfakhar گفته است :

اول اینکه ساخت متای اتوماتیک به چه دردتون می خوره رو نمی دونم چونت لازمه متای مورد نظر رو دستی بسازید تا پستهایی که دارای اون مقدار هستند اول نمایش داده بشند  و الا که نیازی به اینکار نیست

برای اینکه پست هایی که متاتگ نداشته باشند رو نتایج نمایش نمیده. باید متای پیشفرضی بهش داد.

در در 11‏/4‏/2016 at 06:32، imanfakhar گفته است :

دوم اینکه من عرض کردم از کد اون تایپیک برای ساخت تابع استفاده کنید نه اینکه اون تابع رو کپی کنید 

کد رو برای تست کپی کرده بودم و یک جا بی دقتی کرده بودم که کار نکرده بود. فکر می کردم مشکل از نوع قالب بوده که کدها کار نکرده.

در در 11‏/4‏/2016 at 08:17، imanfakhar گفته است :

برای اینکه به کل پستها متا با مقدار دیفالت بدید یک قالب برگه با کدهای زیر بسازید :

عالی بود.

برای نمایش دسته ها هم به همین شکل استفاده کردم. باید مطالب شما رو که جاهای مختلف گفته شده رو یک کتابچه آموزشی کنن و جهت ارتقاء وب فارسی در وب منتشر کنند...

ویرایش شده توسط merhzar_h
لینک به ارسال

یک سوال .

چطور میتونم کوئری برای مطالب بر اساس این متا بنویسم

مثلا پست ها که postorder اونها کوچکتر از 20 باشه یا بین 5 و 20 باشه ...

لینک به ارسال
$query = new WP_Query( array (
	'meta_query'             => array(
		array(
			'key'       => 'postorder',
			'value'     => '5,20',
			'compare'   => 'BETWEEN',
			'type'      => 'NUMERIC',
		),
	),
'orderby'	=>	'meta_value',	
) );

 

لینک به ارسال

یه مشکل برای

در در 11‏/4‏/2016 at 06:32، imanfakhar گفته است :

add_action( 'pre_get_posts', 'foo_modify_search_query_custom_orderby' );
function foo_modify_search_query_custom_orderby( $query ) {
    if ( ! is_admin() && $query->is_main_query() && is_search() )
        $query->set( 'meta_key', 'postorder' );
        $query->set( 'orderby', 'meta_value' );
}

 

یه مشکل برای این کوئری هست که کل کوئری های داخل سایت رو تغییر میده. مثلا من ترتیب رو نزولی یا سعودی کنم کل پست ها حتی در پنل اصلی وردپرس تغییر کرده اند و بر اساس تاریخ سرت میشن ...

در 11 ساعت قبل، imanfakhar گفته است :

$query = new WP_Query( array (
	'meta_query'             => array(
		array(
			'key'       => 'postorder',
			'value'     => '5,20',
			'compare'   => 'BETWEEN',
			'type'      => 'NUMERIC',
		),
	),
'orderby'	=>	'meta_value',	
) );

 

واقعا ممنون و شرمنده که وقتتون رو میگیرم ...

خواستم 5 پست از پست های مورد اشاره رو بصورت رندوم نمایش بدم. هر کاری کردم نشد ...

این کد در ابتدا استفاده کردم بازم کار نکرد

remove_all_filters('posts_orderby');

 

ویرایش شده توسط merhzar_h
لینک به ارسال
add_action( 'pre_get_posts', 'foo_modify_search_query_custom_orderby' );
function foo_modify_search_query_custom_orderby( $query ) {
    if ( ! is_admin() && $query->is_main_query() && is_search() ) {
        $query->set( 'meta_key', 'postorder' );
        $query->set( 'orderby', 'meta_value' );
}

}

 

لینک به ارسال
در 54 دقیقه قبل، merhzar_h گفته است :

خواستم 5 پست از پست های مورد اشاره رو بصورت رندوم نمایش بدم. هر کاری کردم نشد ...

$query = new WP_Query( array (
	'meta_query'             => array(
		array(
			'key'       => 'postorder',
			'value'     => '5,20',
			'compare'   => 'BETWEEN',
			'type'      => 'NUMERIC',
		),
	),
'orderby'	=>	'rand',	
'posts_per_page' =>	5
) );

 

لینک به ارسال
در در 16‏/4‏/2016 at 16:03، imanfakhar گفته است :

add_action( 'pre_get_posts', 'foo_modify_search_query_custom_orderby' );
function foo_modify_search_query_custom_orderby( $query ) {
    if ( ! is_admin() && $query->is_main_query() && is_search() ) {
        $query->set( 'meta_key', 'postorder' );
        $query->set( 'orderby', 'meta_value' );
}

}

 

ممنون از راهنمایی هاتون.

من از این دستور به صورت زیر برای دسته بندی ها استفاده کردم.

add_action( 'pre_get_posts', 'foo_modify_cat_query_custom_orderby' );
function foo_modify_cat_query_custom_orderby( $query ) {
    if ( ! is_admin() && $query->is_main_query() && is_category() ) {
        $query->set( 'meta_key', 'postorder' );
        $query->set( 'orderby', 'meta_value' );
}}

مشکل اینه که کل پست هایی پست متای دیفالت دارند (200) از تاریخ پست های اخر به پست های اول سرت میکنه و پست های جدید بالا قرار نمیگیرند. یا همان دسته هایی که متای تعریف شده جهت قرار گرفت در بالای نتایج هستند در ادامه پست ها هم به این شکل هستند. (این موضوع برای جستجو هم هست)

ایا راهی هست که بشه پست های بعد از سرت بر اساس متای تعریف شده را  به ترتیب تاریخ ثبت نمایش داد ؟

ضمنا این دستور برای اعمال در چند دسته خاص کار نکرد :

    if ( ! is_admin() && $query->is_main_query() && is_category(13,15,17) ) {

چه چیزی جای این باید استفاده کرد ؟

بازم ممنون...

لینک به ارسال
در 10 دقیقه قبل، merhzar_h گفته است :

ایا راهی هست که بشه پست های بعد از سرت بر اساس متای تعریف شده را  به ترتیب تاریخ ثبت نمایش داد ؟

یک راه پیدا کردم ولی باید متاهای داده شده را تغییر بدم تا سرت به درستی انجام بشه .

        $query->set( 'meta_key', 'postorder' );
        $query->set( 'orderby', 'meta_value' );
        $query->set( 'order', 'ASC' );

 

لینک به ارسال
در در 11‏/4‏/2016 at 08:17، imanfakhar گفته است :

برای اینکه ...

این مشکل هست و حل نشد :

در 1 ساعت قبل، merhzar_h گفته است :

ممنون از راهنمایی هاتون.

من از این دستور به صورت زیر برای دسته بندی ها استفاده کردم.


add_action( 'pre_get_posts', 'foo_modify_cat_query_custom_orderby' );
function foo_modify_cat_query_custom_orderby( $query ) {
    if ( ! is_admin() && $query->is_main_query() && is_category() ) {
        $query->set( 'meta_key', 'postorder' );
        $query->set( 'orderby', 'meta_value' );
}}

مشکل اینه که کل پست هایی پست متای دیفالت دارند (200) از تاریخ پست های اخر به پست های اول سرت میکنه و پست های جدید بالا قرار نمیگیرند. یا همان دسته هایی که متای تعریف شده جهت قرار گرفت در بالای نتایج هستند در ادامه پست ها هم به این شکل هستند. (این موضوع برای جستجو هم هست)

ایا راهی هست که بشه پست های بعد از سرت بر اساس متای تعریف شده را  به ترتیب تاریخ ثبت نمایش داد ؟

ضمنا این دستور برای اعمال در چند دسته خاص کار نکرد :


    if ( ! is_admin() && $query->is_main_query() && is_category(13,15,17) ) {

چه چیزی جای این باید استفاده کرد ؟

بازم ممنون...

 

لینک به ارسال
$query->set( 'orderby' => array( 'meta_value' => 'DESC', 'date' => 'ASC' ) );
 if ( ! is_admin() && $query->is_main_query() && (is_category(13) || is_category(15) || is_category(17)) ) {

 

لینک به ارسال
در 12 ساعت قبل، imanfakhar گفته است :

$query->set( 'orderby' => array( 'meta_value' => 'DESC', 'date' => 'ASC' ) );

به محض اضافه کردن این سایت صفحه سفید میاد

در 12 ساعت قبل، imanfakhar گفته است :

if ( ! is_admin() && $query->is_main_query() && (is_category(13) || is_category(15) || is_category(17)) ) {

اصلا به این فکر نکرده بودم!

ممنون.

لینک به ارسال
نقل قول

به محض اضافه کردن این سایت صفحه سفید میاد

ببخشید چک کنید:

$query->set( 'orderby', array( 'meta_value' => 'ASC', 'date' => 'DESC' ) );

 

لینک به ارسال

به گفتگو بپیوندید

هم اکنون می توانید مطلب خود را ارسال نمایید و بعداً ثبت نام کنید. اگر حساب کاربری دارید، برای ارسال با حساب کاربری خود اکنون وارد شوید .

مهمان
ارسال پاسخ به این موضوع ...

×   شما در حال چسباندن محتوایی با قالب بندی هستید.   حذف قالب بندی

  تنها استفاده از 75 اموجی مجاز می باشد.

×   لینک شما به صورت اتوماتیک جای گذاری شد.   نمایش به صورت لینک

×   محتوای قبلی شما بازگردانی شد.   پاک کردن محتوای ویرایشگر

×   شما مستقیما نمی توانید تصویر خود را قرار دهید. یا آن را اینجا بارگذاری کنید یا از یک URL قرار دهید.

×
×
  • اضافه کردن...