Razor View Engine автоматически применяя кавычки?

Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.

Например, ниже - класс ученика, который будет использовать его в нашем коде.

public class Student {

    private int id;

    public int getId() {
        return this.id;
    }

    public setId(int newId) {
        this.id = newId;
    }
}

Приведенный ниже код дает вам исключение с нулевым указателем.

public class School {

    Student obj_Student;

    public School() {
        try {
            obj_Student.getId();
        }
        catch(Exception e) {
            System.out.println("Null Pointer ");
        }
    }
}

Поскольку вы используете Obj_Student, но вы забыли инициализировать его, как в правильном коде, показанном ниже:

public class School {

    Student obj_Student;

    public School() {
        try {
            obj_Student = new Student();
            obj_Student.setId(12);
            obj_Student.getId();
        }
        catch(Exception e) {
            System.out.println("Null Pointer ");
        }
    }
}
26
задан DanH 10 February 2012 в 20:37
поделиться

2 ответа

Razor автоматически HTML-экранирует весь вывод кода.
Вы можете предотвратить это, написав @Html.Raw(...)

В качестве альтернативы, вы можете поместить кавычки в буквальный текст:

<li class="@(active ? "active" : "")>

Ваш пример работает, потому что у вас фактически нет кавычек.
Сгенерированный источник HTML читает <li class=active>.

15
ответ дан SLaks 10 February 2012 в 20:37
поделиться
  • 1
    вероятно, время для обновления 2,3 советов 2.6 and below или даже 3.4 and below – Davos 25 September 2018 в 07:09
  • 2
    вероятно, время для обновления 2,3 советов 2.6 and below или даже 3.4 and below – Davos 25 September 2018 в 07:09
  • 3
    вероятно, время для обновления 2,3 советов 2.6 and below или даже 3.4 and below – Davos 25 September 2018 в 07:09
  • 4
    вероятно, время для обновления 2,3 советов 2.6 and below или даже 3.4 and below – Davos 25 September 2018 в 07:09
  • 5
    вероятно, время для обновления 2,3 советов 2.6 and below или даже 3.4 and below – Davos 25 September 2018 в 07:09

Только что столкнулся с этим странным поведением. По логике должно работать следующее.

@(Model.IsTablet ? "data-options='is_hover: false'" : "")

, но отображается как

data-options="'is_hover:" false&#39;=""

Как утверждает Дэн, это работает правильно

@(Model.IsTablet ? "data-options=is_hover:false" : "")

рендеринг, как в первом примере.

data-options="is_hover:false"

, но если вы добавляете пробел в атрибут, он нарушает все странные вещи, которые делает asp.net 4.0, и думает, что ваш атрибут заканчивается этим пробелом.

И это не означает выхода html, поскольку действительный синтаксис html не работает, и весь смысл бритвы в том, что синтаксис бритвы должен работать с действительным html, а не нарушать его.

3
ответ дан eaglestorm 10 February 2012 в 20:37
поделиться
Другие вопросы по тегам:

Похожие вопросы: