我使用我想定制我的需要WordPress的插件,但我很新的JavaScript的选择。该插件计算两个邮政编码之间的距离,即$距离。我创建了一个基于车辆大小的不同值的下拉菜单。我想要做的是显示距离乘以分配给每个车辆尺寸的值(这是每英里的成本)。任何帮助,将不胜感激。谢谢。如何乘法结果基础上,从下拉菜单
<?php
/**
* Plugin Name: WP Distance Calculator
* Plugin URI: http://phpcodingschool.blogspot.com/
* Description: This plugin claculates distance between two near by locations.
* Version: 1.0.0
* Author: Monika Yadav
* Author URI: http://phpcodingschool.blogspot.com/
* License: GPL2
*/
class DistanceWPCalculator
{
public function __construct()
{ //action definations
add_shortcode('distance_calculator', array(&$this, 'distanceWPfrontend'));
add_action('wp_ajax_nopriv_distancewpcalculator', array(&$this, 'distancewpcalculator_calculate'));
add_action('wp_ajax_distancewpcalculator', array(&$this, 'distancewpcalculator_calculate'));
add_action('init', array(&$this, 'init'));
}
public function init()
{
wp_enqueue_script('distancewpcalculator', plugin_dir_url(__FILE__) . 'js/calculatedistance.js', array('jquery'));
wp_localize_script('distancewpcalculator', 'DistanceCalculator', array(
'ajaxurl' => admin_url('admin-ajax.php')
));
?>
<script>
var ajaxurl = "<?php echo admin_url('admin-ajax.php'); ?>";
</script>
<?php
wp_enqueue_style('DistanceWPCalculator-Style', plugin_dir_url(__FILE__) . 'css/style.css', array(), '0.1', 'screen');
}
public function distancewpcalculator_calculate()
{
// The $_POST contains all the data sent via ajax
if (isset($_POST)) {
$from = urlencode($_POST['from']);
$to = urlencode($_POST['to']);
$data = file_get_contents("http://maps.googleapis.com/maps/api/distancematrix/json?origins=$from&destinations=$to&language=en-EN&sensor=false");
$data = json_decode($data);
$time = 0;
$distance = 0;
foreach($data->rows[0]->elements as $road) {
$time += $road->duration->value;
$distance += $road->distance->value;
}
$time =$time/60;
$distance =round($distance/1609.344);
//Output
if($distance!=0){
echo "<div id='result_generated'>";
echo "From: ".$data->origin_addresses[0];
echo "<br/>";
echo "To: ".$data->destination_addresses[0];
echo "<br/>";
echo "Time: ".gmdate("H:i", ($time * 60))." hour(s)";
echo "<br/>";
echo "Distance: ".$distance." mile(s)";
echo "</div>";
}else{
echo "Sorry only nearby distance can be calculated.";
}
}
die();
}
//Function to display form on front-end
public function distanceWPfrontend($atts) {
?>
<form method ="post" id="calculator" >
<div class="DC_title">Distance Calculator</div>
<input type="text" id="from" name="from" placeholder="From.."></br>
<input type="text" id="to" name="to" placeholder="To.."></br>
<select id="carType" onchange="carsize()">
<option value=".45">Motorcycle</option>
<option value=".6">Small Sedan</option>
<option value=".65">Large Sedan</option>
<option value=".7">Wagon/Hatchback</option>
<option value=".7">Small SUV</option>
<option value=".8">Large SUV</option>
<option value=".8">Minivan</option>
<option value=".75">Small Truck</option>
<option value=".8">Large Truck</option>
</select>
<input type="button" id="calculate" name="calculate" value="Calculate">
</form></br>
<div id="result"></div>
<?php
}
}
$distancewpcalculator = new DistanceWPCalculator();
?>
我一直在玩弄这个永远但由于某种原因$成本完全不返回值。脚本运行时什么都不显示。我尝试将数字更改为整数,并在选择标记中将type =“text”和type =“number”放入下拉列表中。似乎没有任何工作。 – user3517902
如果您在if语句之前vardump $ cost,该怎么办? – kyle