Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Wie gehen Sie mit ', einfachen Anführungszeichen in Personennamen in PHP, Javascript um

Sie müssen eine Menge chaotischer und fehleranfälliger String-Anhängearbeiten durchführen, nur um eine Javascript-Variable auszugeben. Stattdessen sollten Sie die gewünschte Datenstruktur in PHP erstellen (ein Array von Arrays) und dann json_encode() verwenden um ein Javascript-kompatibles Literal auszugeben. Alle Anführungszeichen und dergleichen werden vom Encoder automatisch maskiert.

$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) . ");" ;

Wenn Sie ein Objekt oder ein assoziatives Array haben, wird es als Javascript-Objekt ausgegeben:

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