2016-06-08 2 views
0

Я ищу, чтобы добавить налоговую линию, а также общую общую линию под продуктами. Налог фиксируется в размере 100 долларов США, пока 30% промежуточного итога не превысит 100 долларов США, и в этот момент налог равен 30% (промежуточный итог). Это, как я сделал это, когда я был первоначально писать форму в JavaScript (но понял, что PHP, вероятно, как идти об этом с самого начала идти - я не прав?):Форма заказа PHP - Фиксированная/переменная линия субтотала?

var setup = 0; 
    if(gt*.30>100){ 
     setup = gt*.3; 

    } 
    else if (gt*.3<100 && gt>0){ 
     setup = 100; 

    } 
    else if (gt =0) { 
     setup = 0; 
    } 

Вот шаблон Я отработка: http://www.dyn-web.com/php/order_form/example2.php

РНР код до сих пор:

<?php 


$PRODUCTS = array(
// product abbreviation, product name, unit price 
// follow valid name/ID rules for product abbreviation 
array('prod1', '20" 4:3 (1600 x 1200)', 150), 
array('prod2', '24" 16:9 (1920 x 1200)', 250), 
array('prod3', '32" 16:9 (1920 x 1080)', 300), 
array('prod4', '40" 16:9 (1920 x 1080)', 450), 
array('prod5', '46” LCD 16:9 (1920 x 1080)', 600), 
); 

// functions for example 2 order form 

function getOrderForm2() { 
global $PRODUCTS; 
$tbl = new HTML_Table('', 'demoTbl'); 
$frm = new HTML_Form(); 

// header row 
$tbl->addRow(); 
    $tbl->addCell('Product', 'first', 'header'); 
    $tbl->addCell('Price', '', 'header'); 
    $tbl->addCell('Quantity', '', 'header'); 
    $tbl->addCell('Totals', '', 'header'); 

// display product info/form elements 
foreach($PRODUCTS as $product) { 
    list($abbr, $name, $price) = $product; 

    // quantity text input 
    $qty_el = $frm->addInput('text', $abbr . '_qty', 0, 
     array('size'=>4, 'class'=>'cur', 'pattern'=>'[0-9]+', 'placeholder'=>0, 
       'onchange'=>'getProductTotal(this)', 
       'onclick'=>'checkValue(this)', 'onblur'=>'reCheckValue(this)')); 

    // total text input 
    $tot_el = $frm->addInput('text', $abbr . '_tot', 0, array('readonly'=>true, 'size'=>8, 'class'=>'cur')); 

    // price hidden input 
    $price_el = $frm->addInput('hidden', $abbr . '_price', $price); 

    $tbl->addRow(); 
     $tbl->addCell($name); 
     $tbl->addCell('$' . number_format($price, 2) . $price_el, 'cur'); 
     $tbl->addCell($qty_el, 'qty'); 
     $tbl->addCell($tot_el); 
} 

// subtotal row 
$tbl->addRow(); 
    $tbl->addCell('Equipment Subtotal: ', 'total', 'data', array('colspan'=>3)); 
    $tbl->addCell($frm->addInput('text', 'total', 0, array('readonly'=>true, 'size'=>8, 'class'=>'cur'))); 

//tax row 
$tbl->addRow(); 
    $tbl->addCell('Delivery/Set-Up/Pick-Up: 30% of Equipment Subtotal ($100 minimum): ', 'total', 'data', array('colspan'=>3)); 
    $tbl->addCell($frm->addInput('text', 'tax', 0, array('readonly'=>true, 'size'=>8, 'class'=>'cur'))); 

// total row 
$tbl->addRow(); 
    $tbl->addCell('Grand Total: ', 'total', 'data', array('colspan'=>3)); 
    $tbl->addCell($frm->addInput('text', 'final', 0, array('readonly'=>true, 'size'=>8, 'class'=>'cur'))); 


// additional fields for contact info 
$tbl->addRow(); 
    $tbl->addCell('First Name: ', 'label'); 
    $tbl->addCell(
     $frm->addInput('text', 'first_name', '', array('size'=>36)), 
      '', 'data', array('colspan'=>3) 
    ); 

$tbl->addRow(); 
    $tbl->addCell('Last Name: ', 'label'); 
    $tbl->addCell(
     $frm->addInput('text', 'last_name', '', array('size'=>36)), 
      '', 'data', array('colspan'=>3) 
    ); 


$tbl->addRow(); 
    $tbl->addCell('Email: ', 'label'); 
    $tbl->addCell(
     $frm->addInput('text', 'email', '', array('size'=>36, 
       'pattern' => '^[\w\+\'\.-][email protected][\w\'\.-]+\.[a-zA-Z]{2,}$', 
       'required' => true 
       )), '', 'data', 
     array('colspan'=>3) 
    ); 

$tbl->addRow(); 
    $tbl->addCell('Phone: ', 'label'); 
    $tbl->addCell(
     $frm->addInput('text', 'phone', '', array('size'=>36)), 
      'last', 'data', array('colspan'=>3) 
    ); 

// submit button 
$tbl->addRow(); 
    $tbl->addCell($frm->addInput('submit', 'submit', 'Submit'), 
      'submit', 'data', array('colspan'=>4)); 

$frmStr = $frm->startForm('ex2_result.php', 'post', '', array('onsubmit'=>'return checkSubmit(this);')) . 
    $tbl->display() . $frm->endForm(); 


return $frmStr; 
} 

Я произвольно назначен переменные «налог» и «окончательный» в налоговый и величественные общие строки, но я даже не уверен, как подсчет вычисляется в шаблоне, я не вижу никаких строк summi где угодно. Я чувствую, что могу немного поразмыслить, но я думаю, что смогу заставить себя понять это с небольшой помощью. Может ли кто-нибудь помочь мне правильно настроить это?

ответ

1

Вы можете использовать что-то подобное для расчета и добавления налога в качестве четвертого параметра в php.

foreach($PRODUCTS as $key => $product) { 
    $unit_price = (int) $product[2]; 
    $tax = $unit_price * 0.3; 
    if($tax < 100) { 
     $tax = 100; 
    } 
    $PRODUCTS[$key][3] = $tax; 
} 
print_r($PRODUCTS); 

Это даст выход как

Array 
(
    [0] => Array 
     (
      [0] => prod1 
      [1] => 20" 4:3 (1600 x 1200) 
      [2] => 150 
      [3] => 100 
     ) 

    [1] => Array 
     (
      [0] => prod2 
      [1] => 24" 16:9 (1920 x 1200) 
      [2] => 250 
      [3] => 100 
     ) 

    [2] => Array 
     (
      [0] => prod3 
      [1] => 32" 16:9 (1920 x 1080) 
      [2] => 300 
      [3] => 100 
     ) 

    [3] => Array 
     (
      [0] => prod4 
      [1] => 40" 16:9 (1920 x 1080) 
      [2] => 450 
      [3] => 135 
     ) 

    [4] => Array 
     (
      [0] => prod5 
      [1] => 46” LCD 16:9 (1920 x 1080) 
      [2] => 600 
      [3] => 180 
     ) 

) 

EDIT

Следующая вычисляет налог на суб-общий и присваивает массив с суб-общий и налог. Налог рассчитывается в соответствии с правилами.

$sub_total = 0; 

foreach($PRODUCTS as $key => $product) { 
    $unit_price = (int) $product[2]; 
    $sub_total += $unit_price; 
} 

$tax = $sub_total * 0.3; 
if($tax < 100) { 
    $tax = 100; 
} 

$totals = [$sub_total,$tax]; 

print_r($totals); 
+0

Спасибо за ваш ответ ... Я думаю, что проблема у меня, хотя в том, что налог должен в зависимости от итога, а не каждый пункт, так как это 30% (если больше чем $ 100) из общий порядок. Я думаю, что в случае, вы выписали, общий налог на 3 продукта [1] составит 300 долларов США, когда он должен выйти до 225 долларов США. Имеет ли это смысл? – sixfiveoh

+0

См. Мой обновленный ответ. Помогает ли это? – phreakv6

+0

есть, спасибо! У меня есть еще один вопрос из моего исходного php - // промежуточная строка $ tbl-> addRow(); $ tbl-> addCell ('Equipment Итого:', 'total', 'data', array ('colspan' => 3)); $ tbl-> addCell ($ frm-> addInput ('text', 'total', 0, array ('readonly' => true, 'size' => 8, 'class' => 'cur'))) ; где именно в этом коде суммируется промежуточный итог? Я вижу строку addinput ('text', 'total', 0) для значения промежуточного итога, но не вижу ссылки на любые глобальные или локальные переменные, которые имеют формулу, суммирующую мои итоговые данные ... – sixfiveoh

Смежные вопросы