9

localDB を使用して GPS 座標を管理するための asp.net mvc ポータルを開発しています。私のモデルは次のとおりです。

public class GpsCoordinateViewModel
{
    double Latitute { get; set; }
    double Longitude { get; set; }
}

新しい GpsCoordinate を作成するために自動生成された adn 関連のビューは次のとおりです。

@{
    ViewBag.Title = "Create";
}

<h2>Create</h2>
@using (Html.BeginForm()) {
    @Html.AntiForgeryToken()
    @Html.ValidationSummary(true)

<fieldset>
    <legend>GpsCoordinateViewModel</legend>

    <div class="editor-label">
        @Html.LabelFor(model => model.Latitude)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.Latitude)
        @Html.ValidationMessageFor(model => model.Latitude)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.Longitude)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.Longitude)
        @Html.ValidationMessageFor(model => model.Longitude)
    </div>
    <p>
        <input type="submit" value="Create" />
    </p>
</fieldset>

}

<div>
    @Html.ActionLink("Back to List", "Index")
</div>

@section Scripts {
    @Scripts.Render("~/bundles/jqueryval")
}

問題は、緯度: 41.213321 および経度: 12.123432 (例) として挿入すると、ブレークポイントのローカル値を使用すると、緯度: 41213321 経度: 12123432 になります。場所の精度のために double を使用する必要がありますが、どのように?

私はこの質問も読みました: 通貨/お金の種類に対して MVC で EditorFor() を使用するにはどうすればよいですか?

MVC3 - double 型の小数点以下 3 桁、先行ゼロ付き

しかし、解決策は私にはうまくいきませんでした。なにか提案を?

編集:私の webconfig は:

<system.web>
<httpHandlers>
  <add path="*" verb="*" type="System.Web.HttpNotFoundHandler"/>
</httpHandlers>

<!--
    Enabling request validation in view pages would cause validation to occur
    after the input has already been processed by the controller. By default
    MVC performs request validation before a controller processes the input.
    To change this behavior apply the ValidateInputAttribute to a
    controller or action.
-->
<pages
    validateRequest="false"
    pageParserFilterType="System.Web.Mvc.ViewTypeParserFilter, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"
    pageBaseType="System.Web.Mvc.ViewPage, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"
    userControlBaseType="System.Web.Mvc.ViewUserControl, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=number">
  <controls>
    <add assembly="System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=number" namespace="System.Web.Mvc" tagPrefix="mvc" />
  </controls>
</pages>
<globalization culture="en-US" uiCulture="en-US" />

4

3 に答える 3

7

小数点,の代わりに一部のカルチャが使用されている、cultureinfo が原因である可能性があります。.web.config で次のように設定してみてください。

<system.web>
    <globalization culture="en-US" uiCulture="en-US" />
</system.web>

お役に立てれば

于 2013-04-17T11:35:55.387 に答える
0

それでは、String を DataType として使用し、それを Decimal 値として解析します。

于 2013-04-18T04:31:59.840 に答える
-1

データ型として Double ではなく Decimal を使用すると、役立つ場合があります。

public class GpsCoordinateViewModel
{
    decimal Latitute { get; set; }
    decimal Longitude { get; set; }
}
于 2013-04-17T12:21:30.550 に答える