Я ищу, чтобы добавить налоговую линию, а также общую общую линию под продуктами. Налог фиксируется в размере 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 где угодно. Я чувствую, что могу немного поразмыслить, но я думаю, что смогу заставить себя понять это с небольшой помощью. Может ли кто-нибудь помочь мне правильно настроить это?
Спасибо за ваш ответ ... Я думаю, что проблема у меня, хотя в том, что налог должен в зависимости от итога, а не каждый пункт, так как это 30% (если больше чем $ 100) из общий порядок. Я думаю, что в случае, вы выписали, общий налог на 3 продукта [1] составит 300 долларов США, когда он должен выйти до 225 долларов США. Имеет ли это смысл? – sixfiveoh
См. Мой обновленный ответ. Помогает ли это? – phreakv6
есть, спасибо! У меня есть еще один вопрос из моего исходного 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