Передача параметра для работы с одинарной кавычкой

Как передать параметр функции javascript с включенным '

var name ="Lauren O'Donald";

var htmlAnch='<a onclick="javascript:selectEmployee(1100,"'+name+'");return false;" 
                 href="javascript:void(0);">O'Donald, Lauren</a>';

 $(document).append($(htmlAnch));

Функция javascript не выполняется, так как имя 'Lauren O'Donald' содержит одиночную кавычку.

Как добавить параметр с помощью ' и подготовить динамический html, чтобы он работал?

Вот динамический код для генерации

 var rows = new StringBuffer();

 $(data).each(function(index) {
      rows.append(String.format('<tr><td><a href="No.aspx" 
                onclick="javascript:selectEmployee({3},\"{1} {2}\");return 
               false;">{0}</a></td></tr>',
                String.format("{0}, {1}", this.Surname, this.FirstName),
                this.Surname,
                this.FirstName,
                this.Id
            ));
   });

Ответ 1

Вы можете избежать кавычек/символов, добавив \ к нему:

var string = 'my string with "double quotes" and \'single quotes\'';
var string = "my string with 'single quotes' and \"double quotes\"";
//                                               ^              ^

Использование динамической строки:

var foo = "bar with 'quotes'";
var string = 'my string with "double quotes" and ' + foo.replace(/'/g, "\\'");
//my string with "double quotes" and bar with \'quotes\'

Ответ 2

Вы можете избежать этого, используя \:

var htmlAnch='<a onclick="javascript:selectEmployee(1100,\'Lauren O\'Donald\');return false;" 
             href="javascript:void(0);">O\'Donald, Lauren</a>';

Однако, поскольку вы отметили этот вопрос с помощью jQuery, лучшим решением является подключение события к элементу и использование атрибутов data-* для хранения соответствующей информации, что позволит избежать использования уродливых атрибутов onX. Попробуйте следующее:

var $htmlAnch = $('<a />' {
    text: "O'Donald, Lauren" ,
    data-id: 1100,
    data-name: "Lauren O'Donald"
}).click(function(e) {
    e.preventDefault();
    selectEmployee($(this).data('id'), $(this).data('name'));
});

$(document).append($htmlAnch);

Ответ 3

Напишите свою собственную функцию для возврата escape-строки. Демо

Передайте свою строку как аргумент этой функции, и вы получите строку с экранированием. Вы также можете добавить больше символов в список блокировок, если вы хотите избежать еще нескольких символов.

function remove_quotes(values1)
{
        var values = values1.toString();
        var str = "";
        var blockList = ['"','\'','\\']; // This is the list of key words to be escaped
        var flag = 0;
        for(var i = 0;i<values.length;i++)
        {
            for(var j=0;j<blockList.length;j++)
            {
                if(values[i] == blockList[j])
                {
                    flag = 1;
                    break;
                }
            }
            if(flag == 0)
            str += values[i];
            else
            {
                str += '\\';
                str += values[i];
                flag = 0;
            }
        }
        return str;

    }

Ответ 4

попробуйте что-то вроде этого

    var htmlAnch='<a onclick="javascript:selectEmployee(1100,\'Lauren O\'Donald\');return false;" href="javascript:void(0);">O\'Donald, Lauren</a>';