Mysql
 sql >> Database >  >> RDS >> Mysql

Come gestisci ', virgoletta singola nei nomi di persone in php, javascript

Stai affrontando un sacco di lavoro di aggiunta di stringhe disordinato e soggetto a errori solo per generare una variabile javascript. Quello che dovresti fare invece è costruire la struttura dati che desideri in PHP (un array di array) e quindi utilizzare json_encode() per emettere un letterale compatibile con javascript. Tutte le virgolette e simili verranno automaticamente ignorate dal codificatore.

$itemOutput = array();
if(count($items)) {
    foreach($items as $item) {
        foreach($advisors as $key=>$advisor) {
            if($item['advisor']==$advisor['id']) {
                $ad=$advisor['last_name'];
            }
        }
        $active_icon = ($item['active']=='1'?'tick':'cross');
        $editlink = anchor('auth/admin/members/form/'.$item['id'],$this->bep_assets->icon('pencil'));
        $itemOutput[] = array(
            $item['first_name'],
            $item['last_name'],
            $item['email'],
            $item['parent_email'],
            $item['parent_email2'],
            $ad,
            $this->beep_assets->icon($active_icon),
            $editLink
        );
    }
}
echo "data.addRows(" . json_encode($itemOutput) . ");" ;

Se hai un oggetto o un array associativo, viene emesso come oggetto javascript:

echo json_encode( 
    array( 'a'=>'aa', 'b'=>'bb'),
    array( 'c'=>'cc', 'd'=>'dd')
);
==> [{"a":"aa","b":"bb"},{"c":"cc","d":"dd"}]