Как использовать функции php (wordpress) в файлах PartialJS partials?

Я использую angularjs для загрузки списка моих сообщений Wordpress, однако я не могу заставить любую из моих функций php работать с моим файлом partials.

Я попытался использовать что-то вроде search.php вместо search.html, но при этом получаю такие ошибки, как фатальная ошибка get_post_meta undefined.

Теперь я знаю, что мы не должны смешивать клиентскую сторону со стороной сервера, и я могу использовать какой-то сервис для анализа моего php, но я понятия не имею, как это сделать. Мне нужен мой search.php для рендеринга моих php-тегов, чтобы я мог отображать пользовательские поля и использовать несколько php-функций, которые у меня есть.

Каков наилучший способ сделать это?

На моем шаблоне страницы (.php) у меня есть -

<div id="page" ng-app="app">
        <header>
            <h1>
                <a href="<?php echo home_url(); ?>">Search</a>
            </h1>
        </header>
  <?php if (have_posts()) : ?>
<?php while (have_posts()) : the_post(); ?>

   <div ng-Cloak ng-controller="MyController" class="my-controller">
<div ng-view></div>     
</div>
  <?php endwhile; ?>
 <?php endif; ?>
<?php rewind_posts(); ?>
<div ng-controller="OtherController" class="other-controller">
          <div class="text-center">
          <dir-pagination-controls boundary-links="true" on-page-change="pageChangeHandler(newPageNumber)" template-url="/partials/dirPagination.tpl.html"></dir-pagination-controls>
          </div>
        </div>
        <footer>
            &copy; <?php echo date( 'Y' ); ?>
        </footer>
    </div>

И в моем php файле, который я хочу вызвать в представлении, есть такие функции, как

<?php 
$pcomp1b = get_post_meta(get_the_ID(), 'pa_meta_comp1b', true); 
$pcomp1c = get_post_meta(get_the_ID(), 'pa_meta_comp1c', true);
$pcomp1d = get_post_meta(get_the_ID(), 'pa_meta_comp1d', true); ?>

Математика -   

if( is_numeric( $price1 ) ) {
    $a1 = $price1;
}
$b1 = $pcomp1d;
$sqft1 = str_replace( ',', '', $b1 );

if( is_numeric( $sqft1 ) ) {
    $b1 = $sqft1;
}

$a2 = $pcomp2f;
$price2 = str_replace( ',', '', $a2 );

if( is_numeric( $price2 ) ) {
    $a2 = $price2;
}
$b2 = $pcomp2d;
$sqft2 = str_replace( ',', '', $b2 );

if( is_numeric( $sqft2 ) ) {
    $b2 = $sqft2;
}

$a3 = $pcomp3f;
$price3 = str_replace( ',', '', $a3 );

if( is_numeric( $price3 ) ) {
    $a3 = $price3;
}
$b3 = $pcomp3d;
$sqft3 = str_replace( ',', '', $b3 );

if( is_numeric( $sqft3 ) ) {
    $b3 = $sqft3;
}
$ppsqft1 = ROUND($price1 / $sqft1);
$ppsqft2 = ROUND($price2 / $sqft2);
$ppsqft3 = ROUND($price3 / $sqft3);

$ppsav = ROUND((($ppsqft1 + $ppsqft2 + $ppsqft3)/3));

$b4 = $property_area;
$parea = str_replace( ',', '', $b4 );

if( is_numeric( $parea ) ) {
    $b4 = $parea;
}
$ehvp = $ppsav * $parea;
$homevalue = number_format($ehvp, 0, '.', ',');
echo '$' . $homevalue; ?>

И функции -

<?php if (class_exists('MRP_Multi_Rating_API')){ MRP_Multi_Rating_API::display_rating_result(array('rating_item_ids' => 2, 'show_count' => false, 'result_type' => 'value_rt', 'no_rating_results_text' => 'N/A'));} ?>

Мое приложение script -

var app = angular.module('app', ['ngRoute', 'ngSanitize', 'angularUtils.directives.dirPagination'])

function MyController($scope) {


$scope.currentPage = 1;

$scope.pageSize = 2;

$scope.posts = [];


$scope.pageChangeHandler = function(num) {

console.log('search page changed to ' + num);
  };
}



function OtherController($scope) {

$scope.pageChangeHandler = function(num) {

console.log('going to page ' + num);
  };
}

app.config(function(paginationTemplateProvider) {
    paginationTemplateProvider.setPath('/partials/dirPagination.tpl.html');
});

app.config(function($routeProvider, $locationProvider) {
    $locationProvider.html5Mode(true);

    $routeProvider
    .when('/search-results', {
        templateUrl: myLocalized.partials + 'main.html',
        controller: 'Main'
    })
    .when('/:ID', {
        templateUrl: myLocalized.partials + 'content.html',
        controller: 'Content'
    });
})
app.controller('Main', function($scope, $http, $routeParams) {
    $http.get('wp-json/posts?type=property').success(function(res){
        $scope.posts = res;
    });
})
app.controller('Content', function($scope, $http, $routeParams) {
    $http.get('wp-json/posts?type=property/?filter["posts_per_page"]=25&filter["orderby"]=date&filter["order"]=desc/' + $routeParams.ID).success(function(res){
        $scope.post = res;
    });
});


app.controller('MyController', MyController);
app.controller('OtherController', OtherController);

Итак, как я могу заставить это работать с ng-view и моими частичными шаблонами?

UPDATE

Я использую wordpress api, и я знаю {{tag}}... Мне нужны конкретные вещи, сделанные с php. Есть ли способ препроцитировать его в частичных файлах?

Ответ 1

Если вы хотите включить собственные функции wordpress во внешний php файл (не файл шаблона по умолчанию), вы можете загрузить функции Wordpress по умолчанию, загрузив wp-blog-header.php или wp-load.php в этот файл

как добавление, require_once("/path/to/wordpress/wp-load.php"); в самом начале.

Вы можете обратиться к приведенному ниже коду для запроса http-запроса для получения json-данных,

var app = angular.module('recentPost', []);
app.controller('PostController',  ['$scope', '$http', function($scope, $http) {
    $http.get('your_json_url')
    .then(function(response) {
        console.log( response );    
        /*if ( response.data !== '-1' ) {
            $scope.lists= JSON.parse(response.data.data_received);
        } else {
            $scope.lists= response;
        }*/
    }
}]);

Кроме того, я не вижу смысла использовать AngularJS прямо в wordpress, там уже jQuery + Ajax вы можете использовать, нет смысла загружать дополнительную библиотеку

Ответ 2

Вы можете использовать php файлы для всех связанных с запросами вещей и вызывать этот php файл с помощью какой-либо функции ajax и связывать данные ответа с некоторым div в Angular.. см. пример ниже:

<script type="text/javascript">
      var sampleApp = angular.module('sampleApp', []); // Define new module for our application

      // Create new controller, that accepts two services $scope and $http
      function SampleCtrl($scope, $http) {
        $scope.date = "sample date"; // Bind data to $scope

        // Define new function in scope
        $scope.fetch = function() {
          // Use $http service to fetch data from the PHP web service
          $http.get('api.php').success(function(data) {
            $scope.date = data.date; // Bind the data returned from web service to $scope
          });
        }

      };

      SampleCtrl.$inject = ['$scope', '$http']; // Ask Angular.js to inject the requested services

      sampleApp.controller('SampleCtrl', SampleCtrl); // Initialize controller in pre-defined module
    </script>

Они поместили все php-коды в файл api.php, а onsuccess привязал данные ответа к переменной $scope

Теперь, когда будет нажата кнопка ниже, они будут извлекать данные из файла php и помещать их в файл HTML

<body ng-controller="SampleCtrl">
    <div>
      <!-- When button is clicked the controller will use the fetch() in $scope
      <button ng:click="fetch()">Load date</button>
      <hr>
      <!-- {{date}} is bound to $scope.date and automatically updates when changed ($scope.fetch()) call -->
      <h1>Date is {{date}}!</h1>
    </div>
  </body>

Вы можете использовать этот код как ссылку

Ответ 3

Да, есть способ предварительной обработки php в частичные файлы.

Из командной строки:

cd /var/www/html
php calculate_prices.php > prices.tpl.html

Это выведет вывод файла PHP в файл prices.tpl.html. .tpl.html - это соглашение об именах, обозначающее "html-шаблон".

Другим способом получения обработанного выходного файла PHP является переход на эту страницу на вашем Google Chrome и открытие Chrome Devtools. В панели devtools перейдите на страницу Elements, найдите нужный div, щелкните его и нажмите CTRL + C. Затем создайте новый файл и вставьте его там.


Кроме того, это может быть ненужным шагом: попробуйте

<div ng-include="'myfile.php'"></div

Обратите внимание, что он имеет как двойные кавычки, так и одинарные кавычки. Одиночные кавычки не позволяют ему искать $scope.myfile.php, а вместо этого напрямую загружают этот файл.