我正在尝试通过lumen控制器验证电子邮件。如果正确输入了电子邮件,则应弹出“有效”,但在当前状态下,即使输入正确的电子邮件,也总是“无效”。
namespace App\Http\Controllers;
use Illuminate\Http\Request;
class NewsletterController extends Controller
{
public function subscribe(Request $request)
{
$email = $request->query('email');
echo $email;
function valid_email($email) {
return !!filter_var($email, FILTER_VALIDATE_EMAIL);
}
if( valid_email($email) ) {
return response()->json(["valid"]);
} else {
return response()->json(["invalid"]);
}
}
}
通过jQuery进行AJAX调用
function msg() {
var email = document.getElementById("email").value;
console.log(email);
var email2 = $('input[type=email]').val();
console.log(email2);
event.preventDefault();
$.get("newsletter/subscribe?email + $('input[type=email]').val()", function(data, status){
console.log("data: " + data + "\nStatus: " + status);
})
.done(function() {
//console.log( "done" );
alert("DONE");
})
.fail(function() {
console.log( "error" );
alert("Fail");
})
.always(function() {
//console.log( "finished" );
alert("hz");
});
};
表格
<form class="join-newsletter">
<input id="email" name="email" type="email" placeholder="Enter your email address" class="email-address">
<input onclick="msg()" type="submit" value="Subscribe" class="submit-email button">
</form>
更新的代码:仍显示数据:无效。
答案 0 :(得分:0)
我想您的ajax请求可以更改为。
$.get("/newsletter/subscribe?email="+ $('#email').val()
可能的问题是您没有将email
值正确地发送到控制器。