Ich verwende anglejs, um eine Liste meiner WordPress-Posts zu laden, aber ich kann keine meiner PHP-Funktionen dazu bringen, mit meiner Partials-Datei zu arbeiten.
Ich habe versucht, etwas wie search.php anstelle von search.html zu verwenden, aber wenn ich das tue, erhalte ich Fehler wie fatal error get_post_meta is undefined.
Jetzt weiß ich, dass wir nicht die Client-Seite mit der Server-Seite mischen sollen, und ich kann möglicherweise eine Art Dienst verwenden, um meine PHP-Datei zu analysieren, aber ich habe keine Ahnung, wie ich vorgehen soll. Ich brauche meine search.php, um meine PHP-Tags zu rendern, damit ich benutzerdefinierte Felder anzeigen und mehrere PHP-Funktionen verwenden kann, die ich dort habe.
Was ist der beste Weg, dies zu tun?
Auf meiner Seitenvorlage (.php) habe ich —
<div id="page" ng-app="app">
<header>
<h1>
<a href="https://stackoverflow.com/questions/35285732/<?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>
© <?php echo date( 'Y' ); ?>
</footer>
</div>
Und auf meiner PHP-Datei, die ich aufrufen möchte, gibt es Funktionen wie —
<?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); ?>
Mathematik —
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; ?>
Und Funktionen —
<?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'));} ?>
Mein App-Skript —
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);
Wie kann ich das also mit ng-view und meinen Partials-Vorlagen zum Laufen bringen?
AKTUALISIEREN
Ich verwende die WordPress-API und bin mir bewusst, dass {{tag}} … Ich muss jedoch bestimmte Dinge mit PHP erledigen. Gibt es eine Möglichkeit, es in die Teildateien vorzuverarbeiten?
Dies wäre schrecklich unhaltbar. Erwägen Sie die Verwendung von a WP-RESTful-Pluginund die
$http
Dienst zum Abrufen Ihrer Daten.– Mondwelle99
11. Februar 2016 um 13:39 Uhr
Sie sollten dies nicht tun. Schreiben Sie Ihren eigenen API-Endpunkt für die WP-Site (oder verwenden Sie das oben erwähnte Plugin) und verwenden Sie JavaScript, um Anfragen an die API zu stellen.
– rnevius
11. Februar 2016 um 15:39 Uhr
Was meinen Sie? Derzeit verwende ich ein Plugin für die wp-api. Kann mir einer von euch eine Antwort mit einem Beispiel oder so geben? @moonwave99
– 730wellig
12. Februar 2016 um 6:41 Uhr
Machen Sie sich klar, dass angleJS ein UI-Codierungsframework ist. PHP ist eine serverseitige Sprache. Sie können einfach keine serverseitige Funktion von der angleJS-Variablen aufrufen, weil das verdammte Frontend. Nur JS ist lesbar, deshalb heißt es angleJS und nicht anglePHP.
– Vineet ‘DEVIN’ Dev
17. Februar 2016 um 19:03 Uhr