2012-09-08 77 views
0

我想知道在我的代碼中添加了斜槓的位置。 我使用Ignited Datatables (native-php-version)來爲MySQL中的數據生成ajax表。如何從代碼中刪除斜槓?

來自MySQL的數據顯示爲我想要的,但Ignited Datatables函數允許我將額外的列添加到表中並且問題從那裏開始。

這就是我如何初始化添加額外的列:

->add_column('edit', '<a class="btn btn-mini btn-success" data-toggle="modal" href="#?page=customers-database-edit&id=$1">Edit</a>', 'face_id'); 

額外列我加入應該僅包含鏈接,但在某些原因,JSON是這樣產生的:

\n<a class="\&quot;btn" btn-mini="" btn-success\"="" data-toggle="\&quot;modal\&quot;" href="\&quot;?page=customers-database-edit&amp;id=3\&quot;">Edit&lt;\/a&gt; \n</a> 

所以當你看到問題是代碼被破壞,太多的斜線。

的代碼這是和平承擔一切將與鏈接額外的列:

public function add_column($column, $content, $match_replacement = NULL) 
{ 
$this->add_columns[$column] = array('content' => $content, 'replacement' => $this->explode(',', $match_replacement)); 
return $this; 
} 

foreach($this->add_columns as $field => $val) 
    if($this->check_mDataprop()) 
    $aaData[$row_key][$field] = $this->exec_replace($val, $aaData[$row_key]); 
    else 
    $aaData[$row_key][] = $this->exec_replace($val, $aaData[$row_key]); 


protected function exec_replace($custom_val, $row_data) 

{ 
    $replace_string = ''; 

    if(isset($custom_val['replacement']) && is_array($custom_val['replacement'])) 
    { 
    foreach($custom_val['replacement'] as $key => $val) 
    { 
     $sval = preg_replace("/(?<!\w)([\'\"])(.*)\\1(?!\w)/i", '$2', trim($val)); 
     if(preg_match('/(\w+)\((.*)\)/i', $val, $matches) && function_exists($matches[1])) 
     { 
     $func = $matches[1]; 
     $args = preg_split("/[\s,]*\\\"([^\\\"]+)\\\"[\s,]*|" . "[\s,]*'([^']+)'[\s,]*|" . "[,]+/", $matches[2], 0, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_DELIM_CAPTURE); 

     foreach($args as $args_key => $args_val) 
     { 
      $args_val = preg_replace("/(?<!\w)([\'\"])(.*)\\1(?!\w)/i", '$2', trim($args_val)); 
      $args[$args_key] = (in_array($args_val, $this->columns))? ($row_data[($this->check_mDataprop())? $args_val : array_search($args_val, $this->columns)]) : $args_val; 
     } 

     $replace_string = call_user_func_array($func, $args); 
     } 
     elseif(in_array($sval, $this->columns)) 
     $replace_string = $row_data[($this->check_mDataprop())? $sval : array_search($sval, $this->columns)]; 
     else 
     $replace_string = $sval; 

     $custom_val['content'] = str_ireplace('$' . ($key + 1), $replace_string, $custom_val['content']); 
    } 
    } 

    return $custom_val['content']; 
} 

我有點困惑,在此添加該斜線和whay該鏈接的代碼壞了?

這裏是JSON是如何產生的:

protected function jsonify($result = FALSE) 
    { 
     if(is_null($result)) return 'null'; 
     if($result === FALSE) return 'false'; 
     if($result === TRUE) return 'true'; 

     if(is_scalar($result)) 
     { 
     if(is_float($result)) 
      return floatval(str_replace(',', '.', strval($result))); 

     if(is_string($result)) 
     { 
      static $jsonReplaces = array(array('\\', '/', '\n', '\t', '\r', '\b', '\f', '"'), array('\\\\', '\\/', '\\n', '\\t', '\\r', '\\b', '\\f', '\"')); 
      return '"' . str_replace($jsonReplaces[0], $jsonReplaces[1], $result) . '"'; 
     } 
     else 
      return $result; 
     } 

     $isList = TRUE; 

     for($i = 0, reset($result); $i < count($result); $i++, next($result)) 
     { 
     if(key($result) !== $i) 
     { 
      $isList = FALSE; 
      break; 
     } 
     } 

     $json = array(); 

     if($isList) 
     { 
     foreach($result as $value) 
      $json[] = $this->jsonify($value); 
     return '[' . join(',', $json) . ']'; 
     } 
     else 
     { 
     foreach($result as $key => $value) 
      $json[] = $this->jsonify($key) . ':' . $this->jsonify($value); 
     return '{' . join(',', $json) . '}'; 
     } 
    } 
    } 
+1

你舉的例子不是實際的JSON,我想這是包含在JSON字符串的一部分。請張貼實際生成的JSON,因爲斜槓很可能正確放置在那裏。 – lanzz

回答

0

要從JSON數據刪除斜線,您可以使用PHP的stripslashes()function

這樣:stripslashes($your_data);