You need to do 2 things.
Allow for slave reads. In our Java application we get this through PRIMARY_PREFERRED as a ReadPreference. This allows your application to keep reading through the election periods.
You persistence layer needs some sort of transaction queue such that the writes back off during transitional periods when the replset is electing a new PRIMARY. I've seen proposals for this around the Akka framework where the Actor that actually persists stuff maintains its own in memory queue of requests. During transitional periods, the queue builds up as the Actor waits for the replset to go back to read/write.
The "in memory queue of requests" is enough of a concern for me that I have not pulled the trigger and actually implemented this.